Vorsortieren für TreeMap

Javamoto

Mitglied
Ich habe 20 Objekte (Personen), mit zwei zugewiesene Werten

String T_name;
int richtigeAntworten;

im Rahmen eines Quizes wird nach je 10 Fragen, der int um ein Zufallszahl erhöht:
(int)Math.round( Math.random() * 9 );

Mein Problem:

Bei der Sortierung mit TreeMap kann ich höchstens ein Wert pro Key haben, d.h. wenn Zwei meine Objekten den int Wert 20 haben, da wird nur ein String angezeigt und zwar von den Letzen Person.
(die funktioniert ist nicht das Problem)

Ich möchte dass alle Objekte sichtbar sind, z.B. bei der Ausgangslage:

20 Müller ; 25 Schmitz; 20 Max ; 25 Heike; 23 Peter;

dass das Ergebniss so aussieht:


20 Müller, Max
23 Peter
25 Schmitz, Heike

Bei mir sieht es so aus:

20 Max
23 Peter
25 Heike

Meine Idee war dass ich den ersten Objekt nehme:


schritt 1: 20 Müller mit 25 Schmitz vergleichen, Schlüssel ungleich weiter
schritt 2: 20 Müller mit 20 Max vergleichen -> treffer neues Objekt erstellen 20 Müller, Max
(einfach den String von zweiten Objekt dazu addieren)
schritt 3: 20 Müller, Max mit 25 Heike -> nichts weiter
....
schritt n: 25 Schmitz mit 20 Müller, Max -> nichts weiter ...
...

nach dem Sortierschritt sollte es folgendermaßen aussehen:

20 Müller 20 Max ; 25 Schmitz 25 Heike; 23 Peter;

Dann TreeMap über die neuen Objekte und fertig.
 

Antoras

Top Contributor
Bau dir eine Klasse
Code:
Person(name -> String, answers -> int)
, überschreibe
Code:
equals
und
Code:
hashCode
(oder implementiere noch einen Comparator) und benutze zum Speichern der Objekte ein TreeSet statt einer TreeMap.
 

Javamoto

Mitglied
Zum besseren Überblick worüber ich rede:

Ich habe bereits die Teilnehmer Klasse wo alle meine Objekte definiert sind:

Java:
public class Teilnehmer {
	
	String T_name;
	int richtigeAntworten;
	
	public void nichts (){
		
	}
		
}

Hier meine Sortierung mit Treemap:

Java:
// Liste mit dummy Anwender und deren "richtig beantwortete Fragen"
       
       SortedMap<Integer,String>Sortierte_liste2 = new TreeMap<Integer,String>(Collections.reverseOrder());
       
       Teilnehmer Ben1 = new Teilnehmer();
       Ben1.T_name = "Bernd \n";
       Ben1.richtigeAntworten = n1;
       Sortierte_liste2.put(Ben1.richtigeAntworten, Ben1.T_name);
       
    ...........

       Teilnehmer Ben10 = new Teilnehmer();
       Ben10.T_name = "Noemi \n";
       Ben10.richtigeAntworten = n10;
       Sortierte_liste2.put(Ben10.richtigeAntworten, Ben10.T_name);
       
       Teilnehmer Anwender = new Teilnehmer();
       Anwender.T_name = "--->  " + nam + "  <---" + "\n";
       Anwender.richtigeAntworten = antwortenAnwender;
       Sortierte_liste2.put(Anwender.richtigeAntworten, Anwender.T_name);
       
       
       ArrayList<String> namen;                  
       namen = new ArrayList<String>();
              
       JOptionPane myStatisticWindow = new JOptionPane(); // ----------------------------- hier der Rahmen für das Popupfenster der den Ranking anzeigt -----
       
       JTextArea MyList = new JTextArea("Richtig beantwortete Fragen   \n\n");   // inhalt in den Rahmen
       MyList.setEditable(false);                                        
       MyList.setOpaque(false);
       MyList.setFont(new Font("Arial", Font.PLAIN, 20));   
       
            for (Iterator it = Sortierte_liste2.entrySet().iterator(); it.hasNext(); )   // hier addiert der iterator zeile für zeile die Key / Values 
           {                                                                             // innere schleife 	
             Map.Entry entry = (Map.Entry) it.next();  
             MyList.append(entry.getKey().toString());  
             MyList.append(" " + "Fragen:   ");  
             MyList.append(entry.getValue().toString());  
             MyList.append("\n");  
             
          }  
            myStatisticWindow.showMessageDialog(null, MyList, "Teilnehmer Liste", JOptionPane.DEFAULT_OPTION);  // 
       
          
            
            result = namen.toArray();     
            return result;
            
        }


Warum sollte mir der TreeSet bei der Speicherung was bringen ?
 
Zuletzt bearbeitet:

Antoras

Top Contributor
Warum sollte mir der TreeSet bei der Speicherung was bringen ?
Weil es kein Key/Value-Paar aufnimmt und somit auch nicht nach dem Key sortiert wird. Du fügst momentan nur den Namen und die Anzahl der Antworten in die Map ein, du sollst aber das ganze Objekt abspeichern.

Es gibt außerdem eine foreach-Schleife, die den Iterator ersetzt.
 

Javamoto

Mitglied
Grob - Vorschlag lautet:


A) meiner Klasse "implements Comparable" hinzufügen

B) ein comparator schreiben, der die int Werte der Objekte vergleicht ??

comparator ... da weiß nicht genau was Sache ist :rtfm:

C) Objekt in treeSet speichern

Java:
...
Teilnehmer Ben1 = new Teilnehmer();
       Ben1.T_name = "Bernd \n";
       Ben1.richtigeAntworten = n1
       NewTreeSet.add(Ben1 );
....

D) ...ab zeile 33 Code, statt Iterator, den for each Konstrukt verwenden

Java:
ArrayList<String> namen;                  
       namen = new ArrayList<String>();
.....
 for (Iterator it = Sortierte_liste2.entrySet().iterator(); it.hasNext(); )
.....
result = namen.toArray();     
            return result;

erstezen mit

Java:
ArrayList<String> namen;                  
       namen = new ArrayList<String>();

 for (NewTreeSet richtigeAntworten)       // zum wert die zugehörigen strings addiert ?
           namen.add();                            // mein objekt, richtigeAntworten = int, namen = string
....
result = namen.toArray();     
            return result;
 

Antoras

Top Contributor
Wenn ich es mir recht überlege macht auch ein Set nicht viel Sinn, da du ja bloß nach den Antworten sortieren willst und nicht nach den Namen. Am einfachsten ist wohl eine Liste, in der alle Personen drin stehen und die du dann nachträglich noch sortieren lässt:
Java:
Collections.sort(listOfPersons, new Comparator<Person>() {
	@Override
	public int compare(final Person o1, final Person o2) {
		return o1#answers - o2#answers; // fill in correct code to get the answers
	}
});

foreach funktioniert übrigens so:
Java:
for (Person p : listOfPersons) {
  // use p
}
 

Javamoto

Mitglied
@ Antoras - VIELEN DANK für die Ideen und die Hilfe.

Habe es inzwischen gelöst:

Java:
SortedMap<Integer,String>Sortierte_liste2 = new TreeMap<Integer,String>(Collections.reverseOrder());

Teilnehmer Ben1 = new Teilnehmer();
Ben1.T_name = "Bernd";
Ben1.richtigeAntworten = n1;
String prev = Sortierte_liste2.put(Ben1.richtigeAntworten, Ben1.T_name);    // neu 
if(prev != null){                                                                                        // neu 
Sortierte_liste2.put(Ben1.richtigeAntworten, prev + ", " + Ben1.T_name);   // neu 
}

// alt wurde erstetzt ->  Sortierte_liste2.put(Ben1.richtigeAntworten, Ben1.T_name); 
...........

Teilnehmer Ben10 = new Teilnehmer();
Ben10.T_name = "Noemi";
Ben10.richtigeAntworten = n10;
String prev10 = Sortierte_liste2.put(Ben10.richtigeAntworten, Ben10.T_name);
if(prev10 != null){
Sortierte_liste2.put(Ben10.richtigeAntworten, prev10 + ", " + Ben10.T_name);
}

Teilnehmer Anwender = new Teilnehmer();
Anwender.T_name = "----> " + nam + " <----";
Anwender.richtigeAntworten = antwortenAnwender;
Sortierte_liste2.put(Anwender.richtigeAntworten, Anwender.T_name);


ArrayList<String> namen;
namen = new ArrayList<String>();

JOptionPane myStatisticWindow = new JOptionPane();

JTextArea MyList = new JTextArea("Richtig beantwortete Fragen \n\n"); // inhalt in den Rahmen
MyList.setEditable(false);
MyList.setOpaque(false);
MyList.setFont(new Font("Arial", Font.PLAIN, 20));

for (Iterator it = Sortierte_liste2.entrySet().iterator(); it.hasNext(); )
{ // inner loop
Map.Entry entry = (Map.Entry) it.next();
MyList.append(entry.getKey().toString());
MyList.append(" " + "Fragen: ");
MyList.append(entry.getValue().toString());
MyList.append("\n");

}
myStatisticWindow.showMessageDialog(null, MyList, "Teilnehmer Liste", JOptionPane.DEFAULT_OPTION); //



result = namen.toArray();
return result;

}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
W Vergleichstool für xml-Dateien Tortoise-svn Verknüpfung Allgemeine Java-Themen 2
Zrebna Tipps für Organisation von Code-Reviews nach einem Pull Request. Allgemeine Java-Themen 5
Zrebna Bitte um Empfehlungen für "zeitlose" Bücher bzgl. Backend mit Spring und Beans Allgemeine Java-Themen 25
D Lesbare args für die main-Methode Allgemeine Java-Themen 6
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2
C Daten für Klassifikationsverfahren gewinnen Allgemeine Java-Themen 6
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
I Overlay für Spiele Allgemeine Java-Themen 5
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0
I GUI für kleine Pop-Ups unter Windows Allgemeine Java-Themen 1
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
HarleyDavidson Best Practice Wohin mit der Konfigurationsdatei für Desktopapplikationen? Allgemeine Java-Themen 3
R MAC-Adresse eindeutig für einen PC ? Bezug zu Netzwerk, wieso ? Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben