Sortieren einer Liste

Status
Nicht offen für weitere Antworten.

bambi

Bekanntes Mitglied
Also mein Problem:
ich moechte eine Liste sortieren. In der Liste stehen Strings - eigentlich sind's Mitarbeiter-Nummern.

So. Und nu kommts. :!:
Nein, ich moechte das nicht nach den Mitarbeiter-Nummern sortiereen, sondern:
Zu jeder Nummer gibt es einen Eintrag in einer HashMap. Der Key ist die Mitarbeiter-Nummer (die als String gespeichert
wird). Das Objekt ist eine JavaBean, die Vorname, Nachname usw. enthaelt. Die Liste soll nun so sortiert werden, dass
zB. "Arno Arnensen" mit der Nummer 345 vor "Zenti Zensen" mit der Nummer 123 in der Liste steht.

Und das Wichtigste dabei: es muss fix sein. In der HashMap stehen ca. 8000 Personen. Fuer jede Person
gibt es diese Liste - es muessen also ca 8000 Listen sortiert werden...

Hat jemand 'ne prickelnde Idee? 8)
 
B

Beni

Gast
Mein Vorschlag: Mit Collections.sort hättest du einen O( n log n ) - Algorithmus (für solche Sachen wohl das Schnellste), und mit einem Comparator kannst du eine beliebige Reihenfolge festlegen (du musst nur 2 Objekte vergleichen können).
Mit einem Collator kannst du auch die Strings einfach vergleichen (und das erst noch automatisch nach den Einstellungen die der Benutzer gemacht hat)
 

bambi

Bekanntes Mitglied
Also erst mal DANKE fuer Deine schnelle Antwort.
Ich muss gestehen, dass ich mit dem Comparator bisher noch nicht gearbeitet habe, aber das hier hab' ich jetzt
mal geschrieben:
Code:
public class PersonProxy extends java.lang.Object implements Serializable 
{    
    private String firstName = null;
    private String lastName = null;
    private String employeeNum = null;

    /** ... andere Felder ...*/
    
    /** ... Getter und Setter ...*/

    public int compare(Object obj1,Object obj2){
        int result = 0;
       
       PersonProxy p1 = (PersonProxy) obj1;
       PersonProxy p2 = (PersonProxy) obj2;
       
       String lname1 = p1.getLastName();
       String lname2 = p2.getLastName();
       
       // wenn Nachnamen gleich, dann nach Vornamen sortieren
       result = lname1.compareTo(lname2);
       if(result == 0){

           String fname1 = p1.getFirstName();
           String fname2 = p2.getFirstName();

           result = fname1.compareTo(fname2);
       }
       return result;
    }
...

Hoffe mal, dass das jetzt so halbwegs richtig ist. Wie kann ich das denn jetzt mit meiner Collections
verwenden? Irgendwie bekomm ich's net hin... :bahnhof:
 
B

bygones

Gast
fast richtig :)

1. du musst nicht explizit von Object erben... das ist automatisch
2. eine Möglichkeit wäre, dass deine Klasse das Interface Comparable implementiert. Das hat die Methode compareTo, dass dir die totale Ordnung über deinen Objekten gibt.
3. du schreibst dir eine Comparator Klasse die hat die Methode compare , die dir auch die totale Ordnung definiert, aber unabhängig von der Klasse ist...

3. hat den vorteil wenn du unterschiedl. Sortieren willst je nach Situation. 2. würde ich nehmen, wenn das Sortieren immer das gleiche ist
 

flanker

Aktives Mitglied
Hier eine Variante mit 'Comparable'

Diene Klasse:
Code:
public class PersonProxy implements Comparable, Serializable {

  private String firstName;
  private String lastName;
  private String employeeNum;

  /** ... andere Felder ...*/
   
  /** ... Getter und Setter ...*/


  public int compareTo(Object obj) {
    if (!(obj instanceof PersonProxy)) {
      //hier was tun, ClassCastException wird sowieso gewofen...
      throw new ClassCastException();
    }
    
    PersonProxy pp = (PersonProxy) obj;

    //Kurzschreibform, StringBuffer besser!
    String s1 = lastName + firstName + employeeNum;
    String s2 = pp.getLastName() + pp.getFirstName() + pp.getEmployeeNum();

    return (s1.compareTo(s2));
  }

  public String toString() {
    //Kurzschreibform, StringBuffer besser!
    String str = firstName + " " + lastName + " mit seinem 'employeeNum' " + employeeNum;
    return str;
  }
}


Dann irgendwo machst Du sowas:
Code:
SortedSet s = new TreeSet(deinHashMap.values());

Wie deathbyaclown schon sagte, wenn Sortierungskriterien flexibel halten willst,
Comparator schreiben.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
H Problem beim Sortieren einer HashMap mit TreeSet Allgemeine Java-Themen 4
N Zahlen in Strings einer ArrayList sortieren Allgemeine Java-Themen 14
D LinkedList anhand einer long-Variable der Objekte sortieren Allgemeine Java-Themen 5
G probleme beim sortieren einer ArrayList Allgemeine Java-Themen 8
Fynn29 Liste sortieren ohne Array und ohne vorgegebene Sortierung Allgemeine Java-Themen 24
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
K Verbesserung der Laufzeit beim Sortieren von Einwohnern nach ihrem Geburtsjahr Allgemeine Java-Themen 0
Willi.We Array sortieren Allgemeine Java-Themen 5
L ArrayList sortieren Allgemeine Java-Themen 2
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
MiMa ArrayList sortieren?? Allgemeine Java-Themen 5
C MySQL Tabellen sortieren. Allgemeine Java-Themen 33
Curtis_MC Collections Liste anhand mehrere Kriterien sortieren Allgemeine Java-Themen 6
B Java Mail: Emails sortieren? Allgemeine Java-Themen 5
G Liste (UsageStats) sortieren (Android) Allgemeine Java-Themen 5
FRI3ND Datentypen Date-Array sortieren - Text mitnehmen? Allgemeine Java-Themen 7
P Wertepaare sortieren Allgemeine Java-Themen 3
MiMa Sortieren nach Stellenangaben Allgemeine Java-Themen 7
T Collections ArrayList Sortieren Allgemeine Java-Themen 4
P Listen sortieren Allgemeine Java-Themen 1
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
S Verkettete (Teil)Liste sortieren ( rekursiv bis n) Allgemeine Java-Themen 2
K Strings sortieren: 2 Kritieren Allgemeine Java-Themen 5
B Algortihmus zum linearen Sortieren Allgemeine Java-Themen 1
K ArrayList sortieren Allgemeine Java-Themen 16
heyluigi Random Integer Array Ausgabe nach Größe sortieren Allgemeine Java-Themen 6
H Liste sortieren anhand optionalem Property Allgemeine Java-Themen 3
2 Mehrere Uhrzeiten Sortieren Allgemeine Java-Themen 2
B Counting Sort (Sortieren durch Zählen) Allgemeine Java-Themen 13
H Liste von Objekten generisch sortieren Allgemeine Java-Themen 0
Bluedaishi String Array mit Datum und Uhrzeit String sortieren Allgemeine Java-Themen 6
K Sortieren nach Vorgabe Allgemeine Java-Themen 6
S Erste Schritte Arrayliste alphabetisch sortieren mit Eingabe Allgemeine Java-Themen 9
L Sortieren von "Map<String, Object>" Allgemeine Java-Themen 2
M Sortieren und Leerzeichen Allgemeine Java-Themen 11
W Array Indizes sortieren Allgemeine Java-Themen 16
D Sortieren von Liste zu unperformant Allgemeine Java-Themen 6
E Array alphabetisch sortieren Allgemeine Java-Themen 1
5 Objekte Sortieren lassen Allgemeine Java-Themen 7
P Beim sortieren nullpointerexception Allgemeine Java-Themen 12
G Map nach key sortieren Allgemeine Java-Themen 14
T Array Sortieren (null Werte ans Ende) Allgemeine Java-Themen 2
Gossi Collections (Unbekannte) Liste Sortieren Allgemeine Java-Themen 10
S Int Values sortieren Allgemeine Java-Themen 7
S Sortieren nach Objekten Allgemeine Java-Themen 13
A 2D-array problem (sortieren) Allgemeine Java-Themen 6
T Liste mit GregorianCalendar-Objekten in List einlesen, mit Collection sortieren und ausgeben Allgemeine Java-Themen 3
D priority queue sortieren Allgemeine Java-Themen 10
G List<Person> sortieren Allgemeine Java-Themen 6
K Hashmap sortieren Allgemeine Java-Themen 6
M ArrayList<String>, String häufigkeit sortieren Allgemeine Java-Themen 4
J Wie sortieren? Allgemeine Java-Themen 11
T Liste sortieren Allgemeine Java-Themen 6
K Strings sortieren (knifflig) Allgemeine Java-Themen 7
B JTable nach Icon sortieren Allgemeine Java-Themen 6
C ArrayList (mit Objekten) sortieren Allgemeine Java-Themen 12
J Map nach value sortieren Allgemeine Java-Themen 14
V ArrayList sortieren Allgemeine Java-Themen 7
S String-Array nach Datum sortieren Allgemeine Java-Themen 10
Developer_X Ein Array nach einem bestimmten Attribut sortieren Allgemeine Java-Themen 3
B Sortieren mit generischen Datentypen Allgemeine Java-Themen 3
C ArrayList anhand von zwei Attributen sortieren Allgemeine Java-Themen 4
O Sortieren von Telefonnummern Allgemeine Java-Themen 8
D JTabel sortieren nach mehreren kriterien Allgemeine Java-Themen 3
G Verschachtelte Treemaps, nach Value sortieren Allgemeine Java-Themen 11
K ArrayList nach bestimmtem Muster sortieren Allgemeine Java-Themen 3
I Vector mit Objekten sortieren,Videos mit JMF wiedergeben Allgemeine Java-Themen 6
S Koordinatentupel-Map sortieren?? Allgemeine Java-Themen 16
C ArrayList sortieren (mehrere Kriterien) Allgemeine Java-Themen 6
G ArrayList mit quicksort sortieren Allgemeine Java-Themen 9
Spot84 Vector nach Ressourcetyp sortieren Allgemeine Java-Themen 4
G sortieren von generics Allgemeine Java-Themen 10
Z Als Final deklarierte Klasse im Array sortieren Allgemeine Java-Themen 2
C ArrayList nach Datum sortieren Allgemeine Java-Themen 7
O ArrayList sortieren Allgemeine Java-Themen 8
G ArrayList mit Indices parallel sortieren Allgemeine Java-Themen 8
D HashMap sortieren Allgemeine Java-Themen 2
C Sortieren File[] Allgemeine Java-Themen 5
W [solved] Vector sortieren (Collection / Comparable?) Allgemeine Java-Themen 7
O Vektoren in Vektor sortieren aber mit Java 1.4 (!) Allgemeine Java-Themen 4
T TreeMap durch Comparator mit Generics sortieren Allgemeine Java-Themen 9
M ArrayList sortieren - HashMap mit sort_id vorhanden Allgemeine Java-Themen 2
A Sortieren mit Java Allgemeine Java-Themen 3
J Properties sortieren Allgemeine Java-Themen 6
T HashMap (String, Object(String , int)) nach int sortieren Allgemeine Java-Themen 7
E Bitte um Rat: Sortieren mit ArrayList Allgemeine Java-Themen 2
G Strings die Zahlen enthalten sinnvoll sortieren (A2 < A10 Allgemeine Java-Themen 4
G List mit selbstdefinierten Objekten sortieren Allgemeine Java-Themen 2
F Doppelt verkettete Liste sortieren? Allgemeine Java-Themen 8
S ArrayList nach mehreren Spalten sortieren? Allgemeine Java-Themen 13
G Set absteigend Sortieren Allgemeine Java-Themen 6
B ein spezielles Byte-Array sortieren Allgemeine Java-Themen 11
D Sortieren? Allgemeine Java-Themen 13
N ArrayList sortieren Allgemeine Java-Themen 10
L Nach Häufigkeit sortieren Allgemeine Java-Themen 6
S Dten im Excel sortieren Allgemeine Java-Themen 5
Z Elemente in Vector nach Häufigkeit sortieren. Allgemeine Java-Themen 13
H Objekte Sortieren Allgemeine Java-Themen 4
F Kann man String[] sortieren? Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben