Mehrere Werte mit Comparable sortieren

Status
Nicht offen für weitere Antworten.

belimo

Mitglied
Die originale Aufgabenstellung:

Die Instanzen einer Java-Klasse Person enthalten Daten über Personen.
Die Klasse soll das Interface Comparable<Person> so implementieren, dass Personen durch die Methode compareTo(...) nach Wohnort, Name, Vorname (in dieser Rangfolge) geordnet werden (also so ähnlich wie in einem gedruckten Telefonbuch).
(In SQL würden Sie schreiben „... order by wohnort, name, vorname ...“).
Um Strings zu vergleichen / ordnen sollen Sie die Tatsache benützen, dass die Java-Klasse String das Interface Comparable<String> implementiert.
Schreiben Sie die Methode compareTo(...) der Klasse Person.

public class Person implements Comparable<Person> {
private String wohnort, name, vorname;
...
}

Das Interface Comparable<T> ist gemäss JDK-Help so definiert:

public interface Comparable<T> { public int compareTo(T o); }

Die Klasse String ist gemäss JDK-Help so definiert:

public final class String extends Object implements Comparable<String> ...

soweit so gut, ich wüsste in etwa die Lösung, wenn ich nur nach Wohnort sortieren müsste. Nämlich etwa so:


Code:
public int compareTo(Person p) {
   if (this > p.wohnort) return -1;
   if (this < p.wohnort) return 1;
   return 0;
}

Aber:

1. Würde meine Lösung für 'nur Wohnort' überhaupt stimmen?
2. Wie muss ich vorgehen, wenn ich mehrere Argumente vergleichen möchte?

Danke für eure Tipps.
 
S

SlaterB

Gast
> Würde meine Lösung für 'nur Wohnort' überhaupt stimmen? Gibt das bischen Code 12 Punkte?


warum tippst du das nicht mal in einen Texeditor ein und lässt den Compiler ran?
ich sehe zwei Fehler

geschätzte Punktzahl: 1,5

> Wie muss ich vorgehen, wenn ich mehrere Argumente vergleichen möchte?

wenn keines der beiden if (falls sie mal korrekt werden) erfüllt ist,
dann sind die Wohnorte offensichtlich gleich,
die Operation wurde noch nicht beendet,

statt nun return 0; auszuführen weiter das nächste Attribut vergleichen
 

belimo

Mitglied
Wegen den beiden Fehlern. Wenn schon müsste es so heissen:

Code:
public int compareTo(Person p) { 
   if (this.wohnort > p.wohnort) return -1; 
   if (this.wohnort < p.wohnort) return 1; 
   return 0; 
}

Gäbe das immerhin 2 Punkte? :D

Stimmt da hast du recht, dann wäre die 12 Punkte Lösung sowas?

Code:
public int compareTo(Person p) { 
   if (this.wohnort > p.wohnort) return -1; 
   if (this.wohnort < p.wohnort) return 1; 
   if (this.name > p.name) return -1; 
   if (this.name < p.name) return 1;
   if (this.vorname > p.vorname) return -1; 
   if (this.vorname < p.vorname) return 1;
   
   return 0; 
}

Danke für eine kurze Rückmeldung. :)
 
G

Guest

Gast
belimo hat gesagt.:
Die originale Aufgabenstellung:
1. Würde meine Lösung für 'nur Wohnort' überhaupt stimmen?
Nein.

a) Du kannst eine Person (this) nicht mit einem Wohnort (p.wohnort) vergleichen.

b) Die Operatoren > und < sind auf Objekten nicht definiert.
 

belimo

Mitglied
a) Du kannst eine Person (this) nicht mit einem Wohnort (p.wohnort) vergleichen.

b) Die Operatoren > und < sind auf Objekten nicht definiert.

Fehler a habe ich bereits korrigiert. Es heisst jetzt this.wohnort. Das stimmt, oder?

Bist du dir wegen b sicher? Ich vergleiche ja nicht einfach Objekte, sondern Strings...
 

lhein

Top Contributor
Code:
public int compareTo(Person p) { 
   int result = 0; // Hilfsvariable

   // zuerst den Wohnort vergleichen (Ich nehme für alle Vars mal den Typ String an)
   result = this.wohnort.compareTo(p.wohnort);
   if (result != 0) return result;  // nicht gleich, also gib result zurück

   // dann den Namen vergleichen (Ich nehme für alle Vars mal den Typ String an)
   result = this.name.compareTo(p.name);
   if (result != 0) return result;  // nicht gleich, also gib result zurück

   // zuletzt den Vornamen vergleichen (Ich nehme für alle Vars mal den Typ String an)
   result = this.vorname.compareTo(p.vorname);
   if (result != 0) return result;  // nicht gleich, also gib result zurück

   // alles gleich, also 0 zurückgeben
   return 0; 
}

nicht schön, aber verständlich ;)

lr
 
S

SlaterB

Gast
Tipp in diesem absurden Gespräch, was dir eigentlich auf Jahre jeden Punkt verbieten sollte:
in der Aufgabenstellung ist erklärt, wie man Strings vergleicht,
etwas tricky, aber eindeutig beschrieben

edit: oder Lernen/ Denken einstellen und fertige Lösung abschreiben.. siehe LR

wobei noch zu klären ist, ob am Ende in die richtige Richtung sortiert wird (A-Z oder Z-A)
 

lhein

Top Contributor
SlaterB hat gesagt.:
Tipp in diesem absurden Gespräch, was dir eigentlich auf Jahre jeden Punkt verbieten sollte:
in der Aufgabenstellung ist erklärt, wie man Strings vergleicht,
etwas tricky, aber eindeutig beschrieben

edit: oder Lernen/ Denken einstellen und fertige Lösung abschreiben.. siehe LR

wobei noch zu klären ist, ob am Ende in die richtige Richtung sortiert wird (A-Z oder Z-A)

Das ist dann die Zusatzaufgabe. ;)
Und wenn ich sehe, wie er/sie sich hier vorgetastet hat, ohne wahrscheinlich je mal eine Zeile Code kompiliert / ausprobiert zu haben, dann wird das wohl ohne fremde Hilfe eine nahezu unlösbare Aufgabe :)
 

belimo

Mitglied
SlaterB hat gesagt.:
Tipp in diesem absurden Gespräch, was dir eigentlich auf Jahre jeden Punkt verbieten sollte:
in der Aufgabenstellung ist erklärt, wie man Strings vergleicht,
etwas tricky, aber eindeutig beschrieben

edit: oder Lernen/ Denken einstellen und fertige Lösung abschreiben.. siehe LR

wobei noch zu klären ist, ob am Ende in die richtige Richtung sortiert wird (A-Z oder Z-A)

Auch wenn ich jetzt das Lernen/Denken einstelle und die fertige Lösung von LR abschreibe, stellen sich mir Fragen:

Wenn LR in seinem Code ja innerhalb der Methode compareTo sich selber aufruft, ist das ja Rekursion. Aber im Methodenkopf steht das compareTo(Person p), und LR übergibt danach aber nur einen String z.B. p.wohnort. Wie geht das auf?

Danke jedenfalls für eure Tipps.
 

lhein

Top Contributor
@SlaterB:
Verstehst was ich meine? Der Code löst die Aufgabe, aber verstehen muß man es ja auch ;)
Und wenns Dumm läuft auch noch erklären.... ???:L

lr
 
G

Guest

Gast
belimo hat gesagt.:
Wenn LR in seinem Code ja innerhalb der Methode compareTo sich selber aufruft
Tut er aber nicht, da Person.compareTo(Person) eine andere Methode ist als String.compareTo(String).


Fred
 
S

SlaterB

Gast
bist du dir sicher, dass das eine ausreichend ausführliche Frage war?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
C Mehrere Double werte einlesen Java Basics - Anfänger-Themen 5
M SortedMap mehrere Werte Java Basics - Anfänger-Themen 8
H Eine Methode mehrere Werte zurückgeben lassen Java Basics - Anfänger-Themen 7
F Hashmap, mehrere werte/key Java Basics - Anfänger-Themen 2
J mehrere double Werte einlesen Java Basics - Anfänger-Themen 18
H Mehrere Werte gegeneinander prüfen Java Basics - Anfänger-Themen 18
G mehrere Werte für .equals ? Java Basics - Anfänger-Themen 22
S mehrere Werte zu einem Key abspeichern Java Basics - Anfänger-Themen 3
M mehrere return-Werte Java Basics - Anfänger-Themen 10
F Mehrere Double-Werte aus einem String Java Basics - Anfänger-Themen 3
N Mehrere Werte gleichzeitig in ein Array schreiben? Java Basics - Anfänger-Themen 7
M Mehrere Werte aus einer Methode zurückgeben Java Basics - Anfänger-Themen 7
S HashMap mehrere Keys zu einem Value Java Basics - Anfänger-Themen 3
T Mehrere if bedingungen ohne & Java Basics - Anfänger-Themen 2
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
Buroto Klassen Mehrere .txt Datein verbienden und anschließend auslisten Java Basics - Anfänger-Themen 10
S mehrere TreeSets so speichern, dass man sie miteinander vergleichen kann Java Basics - Anfänger-Themen 1
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
M Mehrere Daten/ Variablen Speichern Java Basics - Anfänger-Themen 9
C mehrere JPanel in ein JFrame bringen Java Basics - Anfänger-Themen 9
L Beim Java Programmstart, mehrere Parameter über die Kommandozeile übergeben Java Basics - Anfänger-Themen 9
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
U Kann man bei Java gleich mehrere Bedingungen prüfen in der If, aber in einem "Satz"? Java Basics - Anfänger-Themen 1
Kotelettklopfer Mehrere Projekte in einem Git verwalten Java Basics - Anfänger-Themen 10
I JAX-RS Mehrere Parameter in Query Java Basics - Anfänger-Themen 3
M mehrere Rückgabenwerte aus Methode Java Basics - Anfänger-Themen 7
A Input/Output Mehrere Csv-Dateien einlesen Java Basics - Anfänger-Themen 2
R Mehrere Buchstaben aus einem String entfernen Java Basics - Anfänger-Themen 1
TimoN11 Java - Eine oder mehrere Eingaben möglich machen Java Basics - Anfänger-Themen 6
M Mehrere Datenbank zugriffe über tomee.xml regeln? Java Basics - Anfänger-Themen 1
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
F Mehrere Server Sockets in einer Anwendung Java Basics - Anfänger-Themen 9
T DoWhile Schleife über mehrere Mothoden Java Basics - Anfänger-Themen 5
B Methoden Mehrere ähnliche Methoden zusammenfassen Java Basics - Anfänger-Themen 24
E Mehrere Eingabezeilen gleichzeitig einlesen Java Basics - Anfänger-Themen 7
C Mehrere Zufallswerte Java Basics - Anfänger-Themen 4
M Dijkstra Algorithmus in Graphen auf mehrere verschiedene Knoten anwenden lassen Java Basics - Anfänger-Themen 11
R Error, wenn mehrere Clients gleichzeitig die Verbindung beenden Java Basics - Anfänger-Themen 16
F Mehrere Exceptions in einem Catch-Block abfangen Java Basics - Anfänger-Themen 12
O Datei in mehrere kleine Dateien umwandeln Java Basics - Anfänger-Themen 47
Henri Mehrere Ordner umbenennen Java Basics - Anfänger-Themen 11
E Mehrere Arrays addieren mit Übertrag Java Basics - Anfänger-Themen 13
J Mehrere paintComponenten in einem Programm Java Basics - Anfänger-Themen 0
F Mehrere Buttons mit einem ActionListener abdecken Java Basics - Anfänger-Themen 24
B Jeweils den Parent bekommen -> mehrere Ebenen Java Basics - Anfänger-Themen 2
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
M Erste Schritte Mehrere eingaben in einer Line vergleichen (if equals...) Java Basics - Anfänger-Themen 6
L Mehrere Jars im Unterordner Java Basics - Anfänger-Themen 2
L LibGDX - mehrere Screens Java Basics - Anfänger-Themen 1
J Sudoku mehrere Lösungen Java Basics - Anfänger-Themen 29
F Mehrere Instanzen der Klasse A EINER Instanz der Klasse B übergeben Java Basics - Anfänger-Themen 3
T Mehrere JFrames gleichzeitig öffnen Java Basics - Anfänger-Themen 6
O Erste Schritte Scanner mehrere male benutzen (Konsole) Java Basics - Anfänger-Themen 7
S mehrere If Bedingungen Java Basics - Anfänger-Themen 5
F Mehrere Zeilen zu einer Zeile zusammenfügen und in eine Datei schreiben Java Basics - Anfänger-Themen 1
B Mehrere Zahlen speichern Java Basics - Anfänger-Themen 60
M mehrere extends? Java Basics - Anfänger-Themen 19
N Datei Zeilenweise einlesen, Ausgabe mehrere Arrays Java Basics - Anfänger-Themen 7
C ButtonController löst mehrere Methoden aus Java Basics - Anfänger-Themen 5
D JPanel mehrere Formen zeichnen Java Basics - Anfänger-Themen 5
B Timer mehrere Male ausführen Java Basics - Anfänger-Themen 4
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
F mehrere eingegebene Zahlen mit Zahlen von 1-9 multiplizieren Java Basics - Anfänger-Themen 18
F Mehrere Konstruktoren? Wofür? Java Basics - Anfänger-Themen 21
J Mehrere Eingabefelder programmiert (Zeigt Fehler an) Java Basics - Anfänger-Themen 6
Jinnai4 Mehrere Textfelder überprüfen Java Basics - Anfänger-Themen 16
N Mehrere Forms auf einem Panel Java Basics - Anfänger-Themen 6
Tommy Nightmare Variable auf mehrere Ungleichheiten prüfen Java Basics - Anfänger-Themen 18
D Mehrere Objekte in ein Objekt zusammenfassen Java Basics - Anfänger-Themen 16
D Input/Output Mehrere Befehle nacheinander ausführen Java Basics - Anfänger-Themen 20
K Mehrere Objekte anlegen Java Basics - Anfänger-Themen 23
N Integers aus Textdatei auslesen und mehrere Arrays erstellen Java Basics - Anfänger-Themen 9
S Verständnis - Frage mehrere SQL Statements in While Schleife Java Basics - Anfänger-Themen 0
J MVC Pattern, mehrere Controller/Views/Models Java Basics - Anfänger-Themen 0
J Mehrere IF Anweisungen und dazugehörige ELSE Java Basics - Anfänger-Themen 6
I Klassen Mehrere Java Klassen in einer .java Datei Java Basics - Anfänger-Themen 7
V Mehrere Dateien aus JFileChooser in eine ArrayList speichern Java Basics - Anfänger-Themen 2
F Mehrere Konstruktoren Java Basics - Anfänger-Themen 10
A Mehrere Radiobuttons Java Basics - Anfänger-Themen 3
B Klassen Mehrere Objekte mit Schleife erstellen - How? Java Basics - Anfänger-Themen 1
T Mehrere Methoden in der main-Methode verknüpfen und aufeinander anwenden Java Basics - Anfänger-Themen 2
V OOP Aufnahme von Dreiecken in ein/mehrere Objekte Java Basics - Anfänger-Themen 0
Q OOP Mehrere Instanzen auf ein Feld Java Basics - Anfänger-Themen 13
C Klasse auf mehrere Objekte zugreifen lassen Java Basics - Anfänger-Themen 26
G Mehrere If-else-Sätze der Reihe nach durchlaufen lassen Java Basics - Anfänger-Themen 2
K Mehrere String.valueOf() kürzer schreiben / "packen"? Java Basics - Anfänger-Themen 2
F String mehrere male ausgeben? Java Basics - Anfänger-Themen 4
H wie mehrere variablen in einfacher for-schleife? Java Basics - Anfänger-Themen 2
H möglichkeiten für for-schleife? (mehrere ausgangsvariablen?) Java Basics - Anfänger-Themen 9
M PdfBox - mehrere Formularseiten Java Basics - Anfänger-Themen 2
Z Mehrere XML-Dateien zu einer zusammenfügen Java Basics - Anfänger-Themen 3
M GUI- mehrere Komponenten auf Container adden Java Basics - Anfänger-Themen 2
I Erste Schritte Resource Bundle - Alles in einem File oder mehrere? => Faktor Performance Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben