ArrayList sortieren mittels Comparator

Status
Nicht offen für weitere Antworten.

magic_halli

Bekanntes Mitglied
Hi,

ich habe eine ArrayList alComparator. Die Einträge darin sehen so aus:
Code:
A;7.46
B;1.0
C;13.2
Ich möchte die Einträge in dieser ArrayList nach den Zahlenwerten(hinterm ;) absteigend sortieren, also ich möchte quasi die Einträge nach dem Maximum sortiert haben. Im Anschluß möchte ich mir dann einfach den ersten Eintrag aus der sortierten ArrayList auslesen - dieser Eintrag ist dann mein Endergebnis, mit dem ich weiterarbeiten will.
Mir geht es um die Ermittlung des Maximums bei den verschiedenen Einträgen. Hierfür würde ich einen Comparator nehmen?!
Hier ist mein bisheriger Code zum Comparator, um nach den Maximalwert zu sortieren:
Code:
Comparator comparatorSort_max = new Comparator() {
        public int compare(Object arg0, Object arg1) {
        	String name1 = (String) arg0;
        	String name2 = (String) arg1;
        	
        	//name-Aussehen: A;7.46 --> hier Zahlenwert extrahieren f. Vergleich
        	String sValue1 = name1.substring(name1.indexOf(";"), name1.length());
        	String sValue2 = name2.substring(name2.indexOf(";"), name2.length());
        	
        	//String-value´s in double casten und vergleichen
        	double dValue1 = new Double(sValue1).doubleValue();
        	double dValue2 = new Double(sValue2).doubleValue();
        	
        	if(dValue1 > dValue2){
        		return dValue1;
        	}else if(dValue1 < dValue2){
        		return dValue2;
        	}
        	
        }
     };
Naja, leider bekomme ich immer Fehlermeldungen bezüglich falschen Rückgabewertes usw. Wenn ich dann was ändere, bekomme ich wieder neue Fehlermeldungen. Ich hangel mich eigentlich nur von Fehler zu Fehler :cry:
Was habe ich falsch gemacht?
Wie kann ich meine ArrayList denn korrekt sortieren?

Danke und Gruß
 

ms

Top Contributor
Code:
        public int compare(Object arg0, Object arg1) {
  	        ...
  	        double dValue1 = new Double(sValue1).doubleValue();
  	        ...
       		return dValue1;
        }
Du solltest einen int zurückgeben, nicht einen double.

ms
 

The_S

Top Contributor
du musst n int zurückgeben und kein double. Steht alles in der API.

-1, 0 oder 1, jenachdem welcher Wert "vorne liegt". Und am Ende solltest du dann ein 0 zurückgeben, falls beide gleich sind.
 

magic_halli

Bekanntes Mitglied
Ok, ich hab´s jetzt so gemacht:
Code:
    Comparator comparatorAuswahlSort_max = new Comparator() { // eigene Vergleichsoperation!
        public int compare(Object arg0, Object arg1) {

...

        	int i=0;
        	if(dValue1 > dValue2){
        		i=1;
        	}else if(dValue1 < dValue2){
        		i=-1;
        	}else if(dValue1 == dValue2){
        		i=0;
        	}
        	
        	return i;

        }
     };
Sollte das so klappen bzw. so ist´s doch syntaktisch richtig, oder?!
 

magic_halli

Bekanntes Mitglied
Alles klar, jetzt hab ich´s gelöst... jeweils einen Comparator für Maximum- und Minimumsortierung gemacht. Klappt prima :)

Danke
 

Marco13

Top Contributor
Die Liste zu sortieren, nur um das größte oder kleinste Element zu finden ist aber überflüssig.
 
S

SlaterB

Gast
Liste einmal durchlaufen, kleinsten/ höchsten Wert nebenher speichern und jeweils mit aktuellen Wert vergleichen,

dauert n Schritte,
Sortieren dagegen im Durchschnitt n log n Schritte

ist meist nur ein theoretisches Problem,
aber nunmal theoretisch konsequent schneller/ langsamer ;)
 

tfa

Top Contributor
Einfach die Liste der Reihe nach durchgehen und jeweils das kleinste bzw. größte Element merken. Das ist mindestens um den Faktor log(n) schneller.
 

magic_halli

Bekanntes Mitglied
Ok, danke. Ich werde das mal so probieren und testen. Wird aber bei meiner doch relativ geringen Menge nicht groß ins Gewicht fallen...

Gruß
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
CptK Datentypen Integer ArrayList sortieren Java Basics - Anfänger-Themen 2
E ArrayList sortieren Java Basics - Anfänger-Themen 16
T ArrayList (Zahlen) aufsteigend sortieren mit Duplikaten Java Basics - Anfänger-Themen 8
N ArrayList sortieren Java Basics - Anfänger-Themen 6
D Best Practice ArrayList sortieren Java Basics - Anfänger-Themen 10
S ArrayList<ArrayList<Integer>> sortieren Java Basics - Anfänger-Themen 3
K Sring ArrayList Manuel sortieren Java Basics - Anfänger-Themen 15
A ArrayList sortieren... Java Basics - Anfänger-Themen 5
M ArrayList<String> alphabetisch sortieren Java Basics - Anfänger-Themen 5
W ArrayList nach Wunsch sortieren Java Basics - Anfänger-Themen 4
G ArrayList sortieren Java Basics - Anfänger-Themen 4
N Arraylist Auto sortieren Java Basics - Anfänger-Themen 7
L ArrayList mit Objekten sortieren Java Basics - Anfänger-Themen 3
L verschachteltes ArrayList nach Geburtsdatum sortieren Java Basics - Anfänger-Themen 4
O ArrayList sortieren Java Basics - Anfänger-Themen 3
V ArrayList Sortieren nach Double funktioniert nicht Java Basics - Anfänger-Themen 3
R ArrayList nach Strings sortieren Java Basics - Anfänger-Themen 6
N ArrayList<ArrayList> sortieren - hilfe bei Comperator Java Basics - Anfänger-Themen 6
M ArrayList sortieren Java Basics - Anfänger-Themen 8
G ArrayList mit Objeken nach Wert sortieren Java Basics - Anfänger-Themen 7
J ArrayList sortieren Java Basics - Anfänger-Themen 4
G Die Objekte eine ArrayList sortieren Java Basics - Anfänger-Themen 50
A Objekte in ArrayList anhand Variable sortieren Java Basics - Anfänger-Themen 10
K ArrayList sortieren mit Quicksort Java Basics - Anfänger-Themen 3
A ArrayList sortieren Java Basics - Anfänger-Themen 7
M ArrayList sortieren? Java Basics - Anfänger-Themen 8
G ArrayList sortieren (K-nearest neighbor/Clusterin) Java Basics - Anfänger-Themen 3
G Eine ArrayList effizient sortieren Java Basics - Anfänger-Themen 5
G ArrayList<Map.Entry.> nach den Values sortieren? Java Basics - Anfänger-Themen 8
G ArrayList sortieren - mal wieder. Java Basics - Anfänger-Themen 6
F ArrayList in ArrayList sortieren Java Basics - Anfänger-Themen 10
M ArrayList sortieren Java Basics - Anfänger-Themen 7
C ArrayListen in einer ArrayList der Grösse nach sortieren Java Basics - Anfänger-Themen 5
G TreeMap sortieren über ArrayList als Value Java Basics - Anfänger-Themen 9
M ArrayList in Array, dann sortieren Java Basics - Anfänger-Themen 15
L ArrayList mit int-Werten sortieren Java Basics - Anfänger-Themen 14
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben