Array nach dem Alphabet sortieren

Barbossa

Mitglied
Hallo Forum,

ich möchte ein Array mit Strings nach dem Alphabet sortieren. Ich kenne bereits einige sortieralgorithmen, jedoch nur für Zahlen und deswegen weiß ich nicht wie ich das ganze auf die Anfangsbuchstaben der Strings übertragen kann.

Ich möchte auch nicht die compareTo() Methode benutzen, sondern den Algorithmus selber implementieren.

Danke im voraus

lg Barbossa
 

Landei

Top Contributor
Sortieralgorithmen funktionieren normalerweise(*) völlig unabhängig vom Datentyp oder der Vergleichsfunktion. Wenn du nicht [c]String.compareTo()[/c] verwenden willst, schreibe dir einen [c]Comparator<String>[/c]. Natürlich reicht es normalerweise nicht, nur den ersten Buchstaben zu vergleichen...

Dann kannst du dir eine Sortierfunktion, die für einen beliebigen [c]Comparator<T>[/c] funktioniert, schreiben, oder einfach [c]Arrays.sort(T[], Comparator<T>)[/c] verwenden.

(*) Ausnahme: BucketSort und ähnliche gehen von einer fest vorgegebenen Anzahl möglicher Werte aus.
 
Zuletzt bearbeitet:

Final_Striker

Top Contributor
Du kannst auch direkt einzelne Zeichen vergleichen.

Java:
char z1 = 'a';
char z2 = 'b';

if(z1 < z2){
   do something
else{
   do something else
}

Die Methode
Code:
indexOf
der Klasse String wird du auch noch brauchen.
 

Barbossa

Mitglied
danke für die schnelle antwort.

ich wusste nicht, dass man zeichen einfach mit dem < operater vergleichen kann.
Geht das auch mit worten? wird dann die länge des Wortes abgefragt oder wirklich die Alphabetische Reihenfolge?

Kannst du deinen Vorschlag nochmal näher erklären? Ich programmiere leider noch nicht so lange als dass ich das verstehen könnte.

Lg Barbossa
 

Landei

Top Contributor
Geht das auch mit worten? wird dann die länge des Wortes abgefragt oder wirklich die Alphabetische Reihenfolge?

Etwas ausführlicher: Mit
Code:
<
u.s.w. können nur die primitiven Datentypen verglichen werden, also
Code:
boolean
,
Code:
byte
,
Code:
short
,
Code:
int
,
Code:
long
,
Code:
float
und
Code:
double
.

Für Objekte gibt es zwei "konkurrierende" Vergleichsverfahren:

1) Der Typ
Code:
T
implementiert das Interface
Code:
Comparable<T>
mit der Methode
Code:
compareTo(T t)
. Je nachdem ob der Rückgabewert kleiner, gleich oder größer 0 ist, ist das aktuelle Objekt kleiner, gleich oder größer als das übergebene, z.B. wäre
Code:
"foo".compareTo("bar")
größer als 0, weil
Code:
"foo"
"größer" als
Code:
 "bar"
ist. Wird dieses Interface implementiert, sagt man auch, der Typ habe eine "natürliche" Ordnung. Viele eingebaute Klassen unterstützen
Code:
Comparable
, z.B.
Code:
String
,
Code:
Date
oder Unterklassen von
Code:
Number
.

Strings werden standardmäßig "alphabetisch" sortiert, genauer gesagt nach Unicode, was z.B. Probleme mit deutschen Umlauten nach sich zieht. Deshalb gibt es noch einen speziellen Mechanismus für "lokalisierte" Ordnungen über die Klasse
Code:
Collator
.

2) Oft braucht man für ein und dieselbe Klasse unterschiedliche Sortiermodi (z.B. auf- und absteigend, eine Person nach Name oder Alter u.s.w.). Da eine Klasse nur eine "natürliche" Ordnung (also
Code:
Comparable
-Implementierung) haben kann, kommt man so nicht weiter. Außerdem hat man manchmal Klassen, die selbst nicht
Code:
Comparable
sind, aber trotzdem sortiert werden sollen. Die Lösung ist, ein separates "Vergleicher-Objekt" vom Typ
Code:
Comparator<T>
zu erstellen. Dieser
Code:
Comparator
hat die Methode
Code:
compare(T first, T second)
, die ähnlich wie
Code:
compareTo
funktioniert.

Oft hat man die Möglichkeit, sich für den gewünschten Mechanismus zu entscheiden (z.B. sortiert ein
Code:
TreeSet
ohne weitere Angaben nach der natürlichen Ordnung, man kann aber auch einen
Code:
Comparator
angeben)
 

Barbossa

Mitglied
Ok zuallererst muss ich euch allen einmal danken für die schnelle Hilfe, besonders dir Landei.

Ich denke grob habe ich verstanden was passiert, jedoch kann ich das noch nicht genau so umsetzen.

Vielleicht wäre es besser wenn ich versuche mal genauer zu erklären was ich überhaupt vorhabe, denn nachdem ich nun weiterprogrammiert habe muss ich nun doch eine Liste alphabetisch sortieren und nicht ein array.

Im endeffekt habe ich Personen in einem sozialen Netzwerk, die alle gewisse Interessen haben. Diese Interessen haben je nachdem wie stark sich eine Person für etwas interessiert ein Gewicht. Diese Interessen und Gewichte sind nun eben in Listen gespeichert und wenn ich nun die Interessen zweier Personen vergleichen will, muss ich zuerst schauen ob beide die gleichen Interessen haben und falls nicht eben die Listen auffüllen und entsprechende Gewichtungen auf 0 setzen.
Soweit bin ich nun. Jetzt haben beide listen die gleichen Elemente, jedoch eben nicht sortiert.

Wie kann erreichen, dass beide Listen jeweils das gleiche Element an gleicher Stelle haben? im endeffekt ist es eigentlich egal ob es alphabetisch ist oder nicht, es muss eben gleich sein, ich dachte mir nur alphabetisch liegt wohl am naheliegendsten.
 
N

new222

Gast
Etwas ausführlicher: Mit < u.s.w. können nur die primitiven Datentypen verglichen werden, also boolean , byte , short , int , long , float und double .

Also boolean kann man IN JAVA nur auf gleichheit[==] oder ungleichheit[!=] testen...das hab ich schon gelernt ;)
 

Final_Striker

Top Contributor
Wie kann erreichen, dass beide Listen jeweils das gleiche Element an gleicher Stelle haben? im endeffekt ist es eigentlich egal ob es alphabetisch ist oder nicht, es muss eben gleich sein, ich dachte mir nur alphabetisch liegt wohl am naheliegendsten.

Warum läuft du nicht einfach über die Liste einer Person und überprüfst ob ihre Interessen in der Interessenliste der zweiten Person vorhanden sind und merkst dir die gleichen Interessen?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Array nach Wert prüfen rekursiv Java Basics - Anfänger-Themen 5
javaluke Erste Schritte Array nach Datentyp sortieren Java Basics - Anfänger-Themen 16
O 2D-Array nach einer Spalte sortieren Java Basics - Anfänger-Themen 22
D Input/Output fehlerhafter Algorithmus zum Ersetzen von Array-Werten nach logischem Schema Java Basics - Anfänger-Themen 1
Ellachen55 Wie nach häufigste Werte im Array suchen? Java Basics - Anfänger-Themen 2
R Benutzereingaben als Array abspeichern nach Programmstart Java Basics - Anfänger-Themen 5
F Array nach Objektattribut durchsuchen Java Basics - Anfänger-Themen 6
M Array nach String durchsuchen und zurückgeben Java Basics - Anfänger-Themen 16
O Array nach gleichen Zahlen prüfen und ausgeben Java Basics - Anfänger-Themen 6
M Array nach Zehnen durchsuchen. Java Basics - Anfänger-Themen 25
B Element in Array nach unten verschieben Java Basics - Anfänger-Themen 11
B Methoden Element aus einem Array löschen, Rest nach vorne verschieben? Java Basics - Anfänger-Themen 4
C eine diagonale von rechts nach links im 2d-array Java Basics - Anfänger-Themen 1
W Array nach String durchsuchen und Ausgeben Java Basics - Anfänger-Themen 8
C Abfrage nach einem Bild im Array Java Basics - Anfänger-Themen 9
J Array nach häufigkeit sortieren Java Basics - Anfänger-Themen 4
S Strings im Array nach Namen sortieren Java Basics - Anfänger-Themen 11
E Arrayeintrag nach Index löschen und Array kürzen Java Basics - Anfänger-Themen 3
B Object in Array nach Prüfung löschen Java Basics - Anfänger-Themen 13
L Array - Nach 2 gleichen Werten stoppen Java Basics - Anfänger-Themen 5
W Elemente in einem Array nach 'oben' verschieben Java Basics - Anfänger-Themen 9
D Eine Stelle eines Char- Arrays nach dem vorkommen in einem ganzem anderem Array überprüfen Java Basics - Anfänger-Themen 20
S Abfrage Objekt-Array nach Datentypen Java Basics - Anfänger-Themen 6
K OOP Objektgefülltes Array nach minWert durchsuchen Java Basics - Anfänger-Themen 5
W Array nach Elemenden die durch 2 teilbar sind durchsehen Java Basics - Anfänger-Themen 9
F.S.WhiTeY Mehrdimensionales array, größere zahlen von innen nach außen Java Basics - Anfänger-Themen 3
C String array nach File array Java Basics - Anfänger-Themen 15
C Datentypen int[][]-Array nach String[][]-Array konvertieren Java Basics - Anfänger-Themen 7
Y Array initialisieren, nach der Abfrage? Java Basics - Anfänger-Themen 3
B String Array nach Int Array Java Basics - Anfänger-Themen 3
D Array nach ungerade zahlen sortieren Java Basics - Anfänger-Themen 6
N Integer Array der Größe nach ordnen Java Basics - Anfänger-Themen 1
S Inhalt von Array nach Zahl durchsuchen Java Basics - Anfänger-Themen 5
A String Array: Suche nach Name -> Wert? Java Basics - Anfänger-Themen 3
S array nach 2 kriterien sortieren Java Basics - Anfänger-Themen 3
T 2D Array nach gleichen Werten durchsuchen Java Basics - Anfänger-Themen 6
A array nach initialisierung final machen? Java Basics - Anfänger-Themen 17
F Casten: Object nach Array Java Basics - Anfänger-Themen 10
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben