zwei Arrays nach gemeinsamme Elemente suchen?

Status
Nicht offen für weitere Antworten.

gustav-mega

Bekanntes Mitglied
Hallo,

ich bin neu hier, und hoffe dass ich auch hier richtig bin :eek:) . Mein Problem ist folgendes:

Ich habe zwei Arrays mit Zahlen, und möchte alle gemeinsamme Zahlen von den zwei Arrays in einem anderen Array speichern, kann jemand mir vielleicht sagen, wie ich das machen könnte?

Gruß,
G.M.
 

DesertFox

Bekanntes Mitglied
meinst du sowas in die richtung?

Code:
int k = 0;
for (int i=0; i<array1.length; i++){

for (int j = 0; j<array2.length; j++){

if (array1[i] == array[2]){

array3[k] = array1[i];
k++;

}
}
 

gustav-mega

Bekanntes Mitglied
erstmal Vielen Dank für die Antwort :) , ja so etwas suche ich und Du meinst wahrscheinlich in Deinem Code in der Zeile 6 statt "array[2]" doch "array2[j]", oder? aber ich suche nach einer anderen Algorithmus, in der so wenige Elemente wie möglich vergelichen werden, da Deine Algorithmus doch eine "Brute Force Algorithmus" ist.

Gruß,
G.M.[/code]
 
R

Roar

Gast
gustav-mega hat gesagt.:
aber ich suche nach einer anderen Algorithmus, in der so wenige Elemente wie möglich angeschaut werden,
wie soll das denn anders gehe nals jedes element des einen arrays mit jedem des anderen zu vergleichen??
 

DesertFox

Bekanntes Mitglied
ähh ja sich mein ich doch, habs halt nur geschwind runtergetippt.
Aber wie soll des mit weniger prüfungen gehen? In meinem Fall werden jede Zahl im ersten Array mit jeder Zahl im zweiten array verglichen, und keine mehr, aber wenn man weniger prüft, kommen doch falsche ergebnisse raus!
 

DesertFox

Bekanntes Mitglied
OMG, liefer ihm die lösung von mir, es gibt keine andere!!! Man was sind des für Aufgaben, oder für Leute, die die machen? Wie will man da Java lernen, wenn man unlösbare aufgaben bekommt??
 
B

Beni

Gast
Zuerst mal die Arrays sortieren... und dann muss man nicht mehr jedes Element mit jedem vergleichen.

Ein Sortieralgorithmus benötigt nur O( n log n ) Zeit, im Gegensatz zum Vergleichen (was O( n^2 ) benötigt), ist also schlussendlich schneller.
 

gustav-mega

Bekanntes Mitglied
Vielleicht eine dumme Frage :oops: , aber wenn ich auch zwei sortierte Arrays habe, muss ich doch trotzdem die Elemente einzeln vergleichen, oder?

Gruß,
G.M.
 
B

Beni

Gast
Du kannst sowas zusammenschreiben (ich habs nicht getestet).
Code:
int[] a = ...
int[] b = ...

// a und b sind die beiden sortieren Arrays
// Dann kannst du sowas schreiben:

int indexA = 0;
int indexB = 0;

int stopA = a.length;
int stopB = b.length;

while( indexA < stopA && indexB < stopB ){
  if( a[indexA] < b[indexB] )
    indexA++;
  else if( a[indexA] > b[indexB] )
    indexB++;
  else{
    // a[indexA] und b[indexB] sind jetzt gleich, also speichern.
    indexA++;
    indexB++;
  }
}

[Edit: Sortieren kann man mit java.util.Arrays#sort]
 
B

bygones

Gast
wenn du zufaellig das eine als Set und nicht als Array hast geht auch: http://java.sun.com/j2se/1.5.0/docs/api/java/util/Set.html#retainAll(java.util.Collection)
 

gustav-mega

Bekanntes Mitglied
Hallo,

die Algorithmus von Beni funktioniert wunderbar, aber dass ich auch richtig verstehe, der Vorschlag von DesertFox hat eine Laufzeit von O(n^2) und der von Beni O(2*n)=O(n), oder?

Gruß,
G.M.
 
B

Beni

Gast
Zuerst sortiert man, dann wird verglichen. Das ergibt O( n log n + n )
Aber das ist = O( n log n ), weil n viel kleiner als n log n ist.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
O zwei Arrays nach Werten durchsuchen und zusammenfügen Java Basics - Anfänger-Themen 3
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
J Inhalte von zwei Arrays vertauschen?! Java Basics - Anfänger-Themen 6
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
P Aus einem Array zwei Arrays machen Java Basics - Anfänger-Themen 3
J Zwei Arrays zippen wirft eine ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 11
C Zwei Integer Arrays "kombinieren" Java Basics - Anfänger-Themen 10
W zwei eindim. arrays zu einem zweidim. ? Java Basics - Anfänger-Themen 7
D Zwei Integer Arrays multiplizieren Java Basics - Anfänger-Themen 3
N Addieren von zwei Arrays Java Basics - Anfänger-Themen 4
G Zwei sortierte Arrays zusammenführen Java Basics - Anfänger-Themen 13
M zwei zweidimensionale arrays multiplizieren Java Basics - Anfänger-Themen 2
M zwei zweidimensionale Arrays addieren Java Basics - Anfänger-Themen 4
H Zwei Arrays zu einem sinnvollen Array Java Basics - Anfänger-Themen 5
G Zwei mehrdimensionale Arrays multiplizieren Java Basics - Anfänger-Themen 9
F zwei arrays verbinden. Java Basics - Anfänger-Themen 3
Torschti Eingabe von Dezimalzahlen (bis zu zwei Kommastellen) Java Basics - Anfänger-Themen 11
A 1 Leerzeichen durch zwei Leerzeichen ersetzen Java Basics - Anfänger-Themen 4
K Warum wird mir hier nach dem ersten Durchlauf zwei mal "welchen Datentyp wollen sie übergeben?" ausgegeben ? Java Basics - Anfänger-Themen 1
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8
krgewb Double mit zwei Nachkommastellen Java Basics - Anfänger-Themen 2
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
berserkerdq2 Habe zwei exceptions, welche ist ein Kommunikationsfehler und welche ein Ausgabefehler? Java Basics - Anfänger-Themen 4
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
B Erste Schritte Bisektion mit zwei Funktionen? Java Basics - Anfänger-Themen 1
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
A Java-XSSFBook: zwei Sheets mergen Java Basics - Anfänger-Themen 5
J Speichern von zwei Variablen durch Auslesen aus einem Numberfield Java Basics - Anfänger-Themen 2
D Zwei verschiedene Intellij Projekte, wie benutze ich wechselseitig objekte Java Basics - Anfänger-Themen 8
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
K mit <<1 kann man mal 2 machen, mit >>2 geteilt durch zwei und was bewirkt <<<1 und >>>1? Java Basics - Anfänger-Themen 5
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
F Abstand zwischen zwei Objekten berechnen wie? Java Basics - Anfänger-Themen 1
M Wie kann ich ein Array in zwei Hälften aufteilen? Java Basics - Anfänger-Themen 12
S Längster Pfad zwischen zwei Vertices in einem Graph Java Basics - Anfänger-Themen 3
S Aktuell beste Methode um zwei Bilder zu vergleichen..? Java Basics - Anfänger-Themen 1
A Zwei XML-Dateien Mergen Java Basics - Anfänger-Themen 14
U Erste Schritte nextGaussian zwischen zwei Werten Java Basics - Anfänger-Themen 19
S Multiplikation von zwei Labels Java Basics - Anfänger-Themen 7
Düsseldorf2002 Datentypen Zwei dimensionale LinkedList Java Basics - Anfänger-Themen 8
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
J Zwei Objekte vergleichen Java Basics - Anfänger-Themen 8
X Zwei Dimensionales Array prüfen Java Basics - Anfänger-Themen 1
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
E Wie gebe ich alle Daten zwischen zwei Zeitpunkten aus? Java Basics - Anfänger-Themen 2
Q Besitzen zwei Strings identische Buchstaben, nur in anderer Reihenfolge? Java Basics - Anfänger-Themen 10
pkm Regexproblem - Wie kann ich zwei oder mehr beliebige Zeichen matchen? Java Basics - Anfänger-Themen 7
A Wieso bekomme ich hier zwei unterschiedliche Ausgaben? Java Basics - Anfänger-Themen 6
R Methode zwei Sortierkriterien der Klasse Comparator übergeben Java Basics - Anfänger-Themen 4
B Collections.sort mit zwei Bedingungen? Java Basics - Anfänger-Themen 4
X Textdatei: zwei-zeilenweise gleiche Zeilen rausschmeißen Java Basics - Anfänger-Themen 21
M Konkatenation von zwei Strings Java Basics - Anfänger-Themen 6
J Problem beim vergleich von zwei Integer Java Basics - Anfänger-Themen 3
D Input/Output Input von zwei Koordinaten validieren und anschließend Werte speichern Java Basics - Anfänger-Themen 7
L Zwei sortierte Subarrays mit gleicher Länge zusammenfügen Java Basics - Anfänger-Themen 2
F Zwei Dimensionles Array Java Basics - Anfänger-Themen 21
I Alle Elemente von zwei Listen vergleichen Java Basics - Anfänger-Themen 1
A Wie zwei zahlen in einer Variable speichern? Java Basics - Anfänger-Themen 7
N Zwei Daten (Datum) miteinander vergleichen, abspeichern, laden Java Basics - Anfänger-Themen 4
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
B Relativen Anteil von zwei Datümer auf Monatsebene umrechnen Java Basics - Anfänger-Themen 130
W Zwei Programme sollen auf eine Klasse zugreifen Java Basics - Anfänger-Themen 18
B Rückgabe von zwei Werten: String und double Java Basics - Anfänger-Themen 14
J Zwei Klassen die sich gegenseitig referenzieren - Bad practice? Java Basics - Anfänger-Themen 4
B Anzahl von Stunden / Tage von zwei Datumswerten ermitteln Java Basics - Anfänger-Themen 1
L Erste Schritte Elemente zwei Schlangen vergleichen Java Basics - Anfänger-Themen 14
N Zwei Strings mit "==" vergleichen warum TRUE Java Basics - Anfänger-Themen 2
D Input/Output InputDialog mit zwei Inputfeldern? Java Basics - Anfänger-Themen 4
D Funktion zwei Arraylisten zu verleichen ob gleich funktioniert nicht Java Basics - Anfänger-Themen 26
S Daten aus zwei Verschiedenen Tabellen in eine ArrayListe Java Basics - Anfänger-Themen 4
D Zwei Strings sind gleich bei if aber nicht true Java Basics - Anfänger-Themen 2
E Best Practice Jar-file mit zwei Klassen und externer Bibliothek über Konsole erzeugen Java Basics - Anfänger-Themen 13
J Logging erzeugt zwei dateien.... Java Basics - Anfänger-Themen 7
S zwei-dimensionales Array Java Basics - Anfänger-Themen 20
R Zwei Attribute gleichzeitig ausgeben Java Basics - Anfänger-Themen 12
T Classpath Zwei gleiche Dateinamen in verschiedenen Projekten möglich? Java Basics - Anfänger-Themen 13
H Bubblesort-Zwei Integer auf Dekade vergleichen. Java Basics - Anfänger-Themen 6
M Wie erzeuge ich die Differenz von zwei Daten in Stunden?? Java Basics - Anfänger-Themen 2
L Den Winkel zwischen zwei Vektoren berechnen! Java Basics - Anfänger-Themen 2
jaleda100 KeyCode – zwei Tasten gleichzeitig Java Basics - Anfänger-Themen 2
M Methoden Zwei Methoden in einem Program laufen lassen...aber wie? Java Basics - Anfänger-Themen 2
M Methoden zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M For-Schleife durch zwei versch. Variablen begrenzen Java Basics - Anfänger-Themen 27
B Erste Schritte Problem bei der Verknüpfung von zwei klassen Java Basics - Anfänger-Themen 8
J Methoden Zwei Methoden die fast das gleiche tun organisieren Java Basics - Anfänger-Themen 3
Bluedaishi der Monat zwischen zwei Datumsangaben Java Basics - Anfänger-Themen 15
J Best Practice Datum Differenz aus zwei Strings ermitteln Java Basics - Anfänger-Themen 8
J Ein Objekt and eine Methode übergeben zwei Schreibweisen? Java Basics - Anfänger-Themen 6
R Threads Pause zwischen zwei Schleifen Java Basics - Anfänger-Themen 1
Aprendiendo Zwei Fragen und ein geerbtes "protected"-Attribut Java Basics - Anfänger-Themen 2
S Parameterübergabe zwischen zwei Programme Java Basics - Anfänger-Themen 4
L Rekursiv zwei Strings vergleichen Java Basics - Anfänger-Themen 3
L Classpath Zwei Bibliotheken enthalten gleiche .class Datei Java Basics - Anfänger-Themen 6
S OOP Zwei JSlider in einer Klasse Java Basics - Anfänger-Themen 2
ArkHeat Erste Schritte Zwei 2-dimensionale Matritzen addieren Java Basics - Anfänger-Themen 0

Ähnliche Java Themen

Neue Themen


Oben