Zwei gleiche Eintraege in ArrayList finden

mindjo

Mitglied
Hallo!

Also ich lese in meinem Programm eine Datei ein, welche pro Zeile 1 Buchstabe und 3 Zahlen enthaelt, jeweils abgetrennt von einem \t (tab), also z.B.

A 1 3 4
B 2 5 2
A 4 0 9
........

So ich muss nun in meinem Programm jede A und jede B Zeile zusammenfuegen, wenn die erste Zahl uebereinstimmt, also wuerde z.B. sowas zusammgengefuegt werden:

A 1 3 5
B 2 2 1
B 1 9 6

--> gemerged wird (A 1 3 5) und (B 1 9 6) zu: AB 1 3 5 9 6

Also ich lese erst mal die zeilen ein, und teile diese in zweii Arraylists
--> ArrayLists sind aber Laufzeit ineffizient, was kann ich da sonst benutzen? Oder irgendwas statt dem array int[]?

Java:
 BufferedReader read = new BufferedReader(new FileReader(filePath));
ArrayList<int[]> allA = new ArrayList<int[]>();
ArrayList<int[]> allB = new ArrayList<int[]>();

String s = null;

                while ((s = read.readLine()) != null) {

                    if (s.contains("A")) {
                 String[] part = s.split("\t");

                        int[] line = new int[3];
//parts[0] ist ja das A oder B
                        line[0] = Integer.parseInt(parts[1]); 
                        line[1] = Integer.parseInt(parts[2]); 
                        line[2] = Integer.parseInt(parts[3]); 
allA.add(line);

                    } else if (s.contains("B")) {

int[] line = new int[3];
//parts[0] ist ja das A oder B
                        line[0] = Integer.parseInt(parts[1]); 
                        line[1] = Integer.parseInt(parts[2]); 
                        line[2] = Integer.parseInt(parts[3]); 
allB.add(line);


                   }
                }

So und nun muss ich ja gleiche eintraege finden, hier habe ich jedoch gar keine idee :S. Das einzige, was mir spontan eingefallen ist, ist eine zweifache Schleife und alles miteinander zu vergleichen, also quasi:

Java:
for (int i =0; i < allA.size();i++) {

for (int j =0; j < allB.size();j++) {

 if (allA.get(i)[0] == allB.get(j)[0]) {

//merge them
// und jetzt aus array loeschen :S
}


}

}

jedoch ist das ja sehr ineffizient, vorallem dass ich dann einen Eintrag im array ersetzen muesste, und dann aus dem ASrray was loeschen waehrend ich noch darueber iteriere :S

aber das groesste problem ist die ineffizienz, alles miteinander zu vergleichen
 

Gucky

Top Contributor
Da ja erstmal keine weiteren Einträge hinzukommen könntest du entweder erst alle A und B Zeilen in je eine ArrayList einlesen und danach das Ganze in je ein Array verwandeln oder du iterierst erst einmal über die Datei und zählst die A und B Zeilen und machst dann anhand des Ergebnisses die Arrays.

Aber Das Ganze mit int zu machen halte ich für unnötig schwer. Viel einfacher wäre es das Ganze mit Strings zu machen und dann die
Code:
[URL="http://openbook.galileocomputing.de/javainsel9/javainsel_04_002.htm#mj5ee730cda1f64998edf27bd440d36bf1"]startsWith()[/URL]
-Methode zu nehmen.

Gruß
Gucky
 

mindjo

Mitglied
Hmm oke, also sind Arrays doch effizienter als arraylists?

Und das mit dem Strings es zu machen, da verstehe ich dich nicht :S

Wenn ich die Zeile als String speicher, habe iich ja sowas wie

A 1 3 4 5;

Aber ich muss ja ueber die erste Zahl mergen... also startsWith hilft mir nur bei dem Anfang ob da ein A oder B steht
 

mindjo

Mitglied
@gegoo

Nicht genau zwei zeilen, sondern zeilen mit jeweils einen gleichen eintrag. aber ich denke, dass ich dass anhand meines beispiels schon anschaulich erklaert habe was ich will
 

Gucky

Top Contributor
Du kannst auch
Code:
startsWith("A 1")
schreiben. Oder die ersten beiden Indizes entfernen mit der
Code:
[URL="http://openbook.galileocomputing.de/javainsel9/javainsel_04_002.htm#mjc6bf6272c679c8daa6715a7e8985f1c6"]substring()[/URL]
-Methode-Methode.
 

kaoZ

Top Contributor
schon mal mit
Code:
.equals()
versucht ?

natürlich auf Strings, aber das sollte ja eigentlich kein problem sein.
 
Zuletzt bearbeitet:

hacke78

Mitglied
Java:
int[] a1 = {4,2,3};
		int[] a2 = {1,2,3};
		ArrayList<int[]> allA = new ArrayList<int[]>();
		allA.add(a1);
		allA.add(a2);
		System.out.println(allA.get(0)[0]);
		Collections.sort(allA, new Comparator<int[]>() {

			@Override
			public int compare(int[] o1, int[] o2) {
				return o1[0] - o2[0];
			}
		});
		System.out.println(allA.get(0)[0]);
Das angewendet auf deine beiden Listen sortiert dir in nlogn beide.
Dann solltest du in linearer Laufzeit deine Listen durchiterieren:
Java:
int i = 0;
int j = 0;
Sry muss weg, Kollgin steht vor der Tür, kann dir das iterieren nicht präsentieren. Aber Idee noch kurz:
mit i durch allA, mit j durch allB, wenn allA(i).get(0)<allB(j).get(0) i++, bei > j++ und bei gleichheit denke ich i++ und j++ und einen Merge... irgendwie so, die Richtung stimmt, obiges Sortieren funktioniert auf jeden Fall.
Beim Merge willst du glaube ich wie du gepostet hast, keine doppelten Elemente:
Java:
HashSet hs = new HashSet();
hs.addall(allA);
hs.addall(allb);
ArrayList result = new ArrayList();
result.addAll(hs);
Tut mir echt leid fürs geschlampe hier unten, aber ich bin überfällig und muss weg :(
 

kaoZ

Top Contributor
Sowas in der Art , zumindest schonmal als Lösungsansatz:

Java:
package versuche;

import java.util.ArrayList;

public class Check {

	ArrayList<String> listA;
	ArrayList<String> listB;
	
	public static void main(String[] args) {
	
		new Check().create();
		

	}
	public void create()
	{
		listA = new ArrayList<String>();
		listB = new ArrayList<String>();
		
		listA.add("eins");
		listB.add("zwei");
		check();
	}
	public void check()
	{
		 for (int x = 0; x < listA.size(); x++ )
         {
             for (int y = 0; y < listB.size(); y++)
             {
                 if (listA.get(x).equalsIgnoreCase(listB.get(y)))
                 {
                	 System.out.println("Bedingung ist wahr"); // oder dein Code
                 }
                 else
                 {

                	 System.out.println("Bedingung ist falsch"); // oder dein Code
                 }
             }
         }
	}
	
}

[EDIT]
Da in diesem Fall die Einträge der listeA nicht mit dem der ListeB übereinstimmen ergibt es false

hätte man jetzt
Java:
listA.add("eins");
listB.add("eins");
wäre der test der Strings true
[/EDIT]
 
Zuletzt bearbeitet:

mindjo

Mitglied
@kaoZ

Das ist genau die Loesung, die ich auch hatte, jedoch wegen angegeben Gruenden lieber umgehen wollte.

@hacke78

Ich verstehe nur hier nicht, wieso du erst ein sortieren machst, bevor das mergen kommt?


Und das verwenden vom HashSet hier ist mir auch iwie unklar :S
 

stg

Top Contributor
@hacke78

Ich verstehe nur hier nicht, wieso du erst ein sortieren machst, bevor das mergen kommt?

Und das verwenden vom HashSet hier ist mir auch iwie unklar

Er sortiert in quasi-linearer Zeit, damit du anschließend in linearer Zeit alle Einträge vergleichen kannst (du musst du einmal durch die Liste laufen und jeweils benachbarte Paare vergleichen). Der Gesamtaufwand bleibt damit quasi-linear (die Hauptarbeit ist das Sortieren). Bei dem anderen Ansatz hast du bereits quadratische Laufzeit, wenn du naiv jedes Element mit jedem anderen vergleichst.

Über den Umweg über das HashSet werden doppelte Einträge rausgeschmissen.

Zum Problem selbst will ich gar nichts weiter sagen, da mir ehrlich gesagt viel zu unklar bleibt, was du tatsächlich _genau_ machen willst.
 
Zuletzt bearbeitet:

DrZoidberg

Top Contributor
Sollst du jeweils zwei Zeilen mergen?

Wie würde das Resultat für dieses Beispiel aussehen?

A 1 3 5
B 2 2 1
B 1 9 6
A 1 8 9
B 3 5 6
B 1 5 2

So?
AB 1 3 5 6 9
AB 1 2 5 8 9
B 2 2 1
B 3 5 6

Oder so?
AB 1 2 3 5 6 8 9
B 2 2 1
B 3 5 6
 

hacke78

Mitglied
Ich sortiere aus folgenden Grund:
Dein "Bruteforceansatz" hat eine assymtotische Laufzeit von n^2.
Du hast schon richtig erkannt, dass hier (je nach Größe deiner Listen) Performanceproblem vorliegt.

Wenn du sortierst, Sortieralgorthmen haben im Regelfall eine Laufzeit von nLogn, kannst du danach in linearer Zeit megen und damit ist deine Gesamtlaufzeit durch nLogn begrenzt. Das ist im Nano/Millisekundenbereich schon bemerkbar bei n=1000, und bei Miogröße von n schon richtig deftig.

Edit : wurde auch schon so beantwortet von stg, wobei ich meines Wissenstandes bei Quasilinearer Laufzeit durch Sortieren wiedersprechen muss. Hier sollte die untere Grenze doch bei nLogn liegen.
 
Zuletzt bearbeitet:

stg

Top Contributor
Edit : wurde auch schon so beantwortet von stg, wobei ich meines Wissenstandes bei Quasilinearer Laufzeit durch Sortieren wiedersprechen muss. Hier sollte die untere Grenze doch bei nLogn liegen.

Das liegt wohl nur daran, dass dir die bedeutung von "quasilinear" im Zusammenhang mit der Zeitkomplexität nicht geläufig ist. Natürlich ist nlog(n) untere Schranke für jeden Sortieralgorithmus, aber genau das wird damit bezeichnet. Sogar noch ein bisschen allgemeiner all solche Algorithmen, die in n(log(n)^k) laufen. Quasilinear deshalb, weil n(log(n)^k) immer noch schneller ist, als jedes Polynom in n mit Exponent größer als 1.

Nachzulesen z.B. hier Time complexity - Wikipedia, the free encyclopedia
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Textdatei: zwei-zeilenweise gleiche Zeilen rausschmeißen Java Basics - Anfänger-Themen 21
T Classpath Zwei gleiche Dateinamen in verschiedenen Projekten möglich? Java Basics - Anfänger-Themen 13
J Methoden Zwei Methoden die fast das gleiche tun organisieren Java Basics - Anfänger-Themen 3
L Classpath Zwei Bibliotheken enthalten gleiche .class Datei Java Basics - Anfänger-Themen 6
O Zweidemensionales Array auf zwei gleiche Zahlen prüfen Java Basics - Anfänger-Themen 15
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
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
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
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
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
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
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
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
J Inhalte von zwei Arrays vertauschen?! Java Basics - Anfänger-Themen 6
O zwei Arrays nach Werten durchsuchen und zusammenfügen Java Basics - Anfänger-Themen 3
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
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
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
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
S OOP Zwei JSlider in einer Klasse Java Basics - Anfänger-Themen 2
P Aus einem Array zwei Arrays machen Java Basics - Anfänger-Themen 3
ArkHeat Erste Schritte Zwei 2-dimensionale Matritzen addieren Java Basics - Anfänger-Themen 0
S Erste Schritte Zwischen zwei Punkten ein Minimumpkt./Maxima finden Java Basics - Anfänger-Themen 1
T OOP Zwei Klassen Testen (Arrary Iterieren) Java Basics - Anfänger-Themen 6
E Eine Instanzvariable und zwei Objekte Java Basics - Anfänger-Themen 14
S Durchschnitt berechnen aus zwei Textfeldern Java Basics - Anfänger-Themen 21
K Zwei Fragen zu Graphics/Graphics2D Java Basics - Anfänger-Themen 5
P Verbindung von Zwei Kreisen löschen ! Java Basics - Anfänger-Themen 6
J Zwei String-Variabeln vergleichen Java Basics - Anfänger-Themen 5
F Vererbung in zwei Richtungen? Java Basics - Anfänger-Themen 14
J Hilfe beim "Verknüpfen" von zwei Klasse Java Basics - Anfänger-Themen 15
N Mit der gleichen BlockingQueue in zwei Klassen arbeiten Java Basics - Anfänger-Themen 12

Ähnliche Java Themen

Neue Themen


Oben