Strings sortieren (knifflig)

kulri

Mitglied
Hallo!

ich möchte beliebige Strings folgendermaßen sortieren: 9, 10, 10a, 10b, 11, 99, 100, aaaaaa, z, z1, za, za1 .........
Groß-/Kleinschreibung kann ignoriert werden.

Ach ja, noch eine Einschränkung: Ich kann nicht vorher abfragen, wie der String aussieht und dem entsprechend meinen Sortieralgorithmus wählen; ich brauche EINEN Algorithmus, der auf alles passt!

Ich probier jetzt schon seit Stunden rum, aber ich kriegs einfach nicht gebacken :(
 

Michael...

Top Contributor
1. die Strings in eine Liste schweissen, z.B. ArrayList
2. einen eigenen Comparator schreiben
3. die Liste per Collections.sort(...) sortieren.
 

kulri

Mitglied
@SlaterB
Danke, die Klasse kann ich gut gebrauchen. Aber für mein Problem hilft die mir auch nicht weiter, den Algo muss ich trotzdem implementieren.

@Michael
Auch danke. Aber welche Klassen oder Methoden ich da verwende ist vollkommen irrelevant, den Algo muss ich in jedem Fall selber implementieren.

Weitere Vorschläge oder Quellcode sind weiterhin willkommen ;)
 
S

SlaterB

Gast
naja, komplett neu programmieren musst du ja eher selber,

Strings muss man Zeichen für Zeichen anschauen und dann einfach nur die Regel Zahl < Buchstabe,
was hast du denn schon programmiert?
 

Janus

Bekanntes Mitglied
Hab mal einen Comparator implementiert, der so sortiert. Bin dafür die Strings Zeichen für Zeichen durchgegangen, hab Zahlen, wenn sie denn an gleicher Position lagen, mit führenden Nullen aufgefüllt und anschließend durch nen Standard Collator gejagt.
 

kulri

Mitglied
Ich hatte es so versucht:

Java:
private long compare(String str1, String str2){
	long val1 = stringToUnicodeSum(str1);
	long val2 = stringToUnicodeSum(str2);
	return val1 - val2;
}

private long stringToUnicodeSum(String str) {
	long unicodeSum = 0;
	long dezimalMultiplier = 1;
	str = str.toLowerCase();
	for(int i = str.length()-1; i >= 0; i--){
		if(str.charAt(i) >= '0' && str.charAt(i) <= '9') unicodeSum += (str.charAt(i)* dezimalMultiplier);
		else unicodeSum += str.charAt(i);
		dezimalMultiplier *= 10;
	}
	System.out.println(unicodeSum);
	return unicodeSum;
}

Aber das funktioniert überhaupt nicht. Ok, Integer werden korrekt sortiert (9 < 10 < 11). Aber wie ich es machen soll, dass auch Strings korrekt sortiert werden (aaaaaaaa < yyy < z) und zusätzlich noch die Hausnummern-Formate (2 < 2a < 2b < 3 < 10 .....) hab ich keinen blassen Schimmer :noe:

Um die Hausnummern-Formate zu handlen hatte ich alle Ziffern mit 65536 multipliziert, um ihnen eine höhere Gewichtung zu geben und zu erreichen, dass 6 < 6a <7, aber das war auch ein Schuß in Ofen.
 
S

SlaterB

Gast
du darfst nicht den ganzen String miteinbeziehen, die Länge und Summe aller Zeichen ist ganz egal,
immer erst nur die ersten Zeichen beider Strings miteinander vergleichen,

hier die compareTo-Methode aus String, von der kannst du abschreiben
(edit: wenn auch bisschen kompliziert, eine for-Schleife geht auch)

Java:
    public int compareTo(String anotherString) {
	int len1 = count;
	int len2 = anotherString.count;
	int n = Math.min(len1, len2);
	char v1[] = value;
	char v2[] = anotherString.value;
	int i = offset;
	int j = anotherString.offset;

	if (i == j) {
	    int k = i;
	    int lim = n + i;
	    while (k < lim) {
		char c1 = v1[k];
		char c2 = v2[k];
		if (c1 != c2) {
		    return c1 - c2;
		}
		k++;
	    }
	} else {
	    while (n-- != 0) {
		char c1 = v1[i++];
		char c2 = v2[j++];
		if (c1 != c2) {
		    return c1 - c2;
		}
	    }
	}
	return len1 - len2;
    }
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
K Strings sortieren: 2 Kritieren Allgemeine Java-Themen 5
N Zahlen in Strings einer ArrayList sortieren Allgemeine Java-Themen 14
G Strings die Zahlen enthalten sinnvoll sortieren (A2 < A10 Allgemeine Java-Themen 4
O regulärer Ausdruck zum durchsuchen eines Strings verwenden Allgemeine Java-Themen 2
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
W JSON parsen eines ,mit JS.stringify erstellten Strings Allgemeine Java-Themen 27
N MySQL mit Strings Allgemeine Java-Themen 3
T Letztes Zeichen eines Strings enfernen Allgemeine Java-Themen 14
P Strings: equals vs == Allgemeine Java-Themen 47
G Objekte mit Strings Aufrufen Allgemeine Java-Themen 8
W Collections Suche Collection, um Strings mit Indizees versehen Allgemeine Java-Themen 47
V Datentypen Graphikrechner 2/Strings und Variablen in Doubles umwandeln Allgemeine Java-Themen 6
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
Meeresgott Best Practice Strings auf Inhalte vergleichen Allgemeine Java-Themen 1
N DNA Strings vergleichen Allgemeine Java-Themen 1
Q-bert Strings aus der JList in eine Datenbank speichern Allgemeine Java-Themen 1
K Vergleich von Strings von Objekten Allgemeine Java-Themen 4
J Strings int textdokumente speicher Allgemeine Java-Themen 3
KeVoZ_ Nacheinander folgende Strings in Textdokument auf neue Zeile schreiben Allgemeine Java-Themen 6
A Vector Strings in Array splitten Allgemeine Java-Themen 6
B Wie vergleiche ich Strings in einer Liste? Allgemeine Java-Themen 5
T Strings über Bluetooth zwischen PC,µc oder Samrtphone senden und empfangen Allgemeine Java-Themen 0
N Methoden Methoden einer Klasse auf Grundlage eines Strings aufrufen Allgemeine Java-Themen 6
K Bestimmten Bereich eines Strings lesen Allgemeine Java-Themen 6
H RegularExpression zwischen zwei Strings Allgemeine Java-Themen 2
Neumi5694 Operatoren regEx für das Erstellen eines Strings verwenden Allgemeine Java-Themen 3
H Strings vergleichen Allgemeine Java-Themen 9
O Mustererkennung in Strings Allgemeine Java-Themen 4
Y String-Collection: längste gemeinsame Strings / Prefixe Allgemeine Java-Themen 3
F Problem mit Strings Allgemeine Java-Themen 8
D Strings chemisch splitten Allgemeine Java-Themen 3
K Wörter in Strings zählen Allgemeine Java-Themen 7
L Strings nach sortiertem String zurück ordnen Allgemeine Java-Themen 0
L Strings nach gleichem Muster ordnen Allgemeine Java-Themen 4
L Fragen für Facharbeit: Analyse von Strings in Java Allgemeine Java-Themen 4
D Strings vergleichen; Komma ignorieren Allgemeine Java-Themen 3
K Java Operatoren mit Strings darstellen Allgemeine Java-Themen 8
G Strings erzeugen Allgemeine Java-Themen 20
B HTML Tags in Strings umwandeln Allgemeine Java-Themen 4
N Input/Output Vergleich von identischen Strings schlägt fehl Allgemeine Java-Themen 5
U Große Liste von Strings mit indiziertem Zugriff Allgemeine Java-Themen 31
A ,,Textformatierungsbefehle" für strings deaktivieren Allgemeine Java-Themen 8
S Strings vergleichen Allgemeine Java-Themen 11
C Strings in Excel einlesen! Allgemeine Java-Themen 2
S Strings gehen "kaputt" wenn ich in CVS ein und wieder auschecke. Allgemeine Java-Themen 2
X Datentypen Prozentualer Abgleich zwischen 2 Strings (Pattern?) Allgemeine Java-Themen 3
R MD5-Hash eines Strings bestimmen Allgemeine Java-Themen 2
C Strings und JSON Objekte so klein wie möglich im Speicher ablegen Allgemeine Java-Themen 5
J String zerlegen in einzelne Strings Allgemeine Java-Themen 7
F Konstanten mir Strings "verknuepfen" Allgemeine Java-Themen 10
1 zwei Strings vergleichen Allgemeine Java-Themen 16
L Object Instanz anhand eines Strings Allgemeine Java-Themen 10
S vector & strings Allgemeine Java-Themen 26
N Strings mit null wiedergabe Splitten Allgemeine Java-Themen 4
P Codierung der strings umändern Allgemeine Java-Themen 10
F 2 Strings zusammenfügen Allgemeine Java-Themen 2
D Strings von HTML befreien Allgemeine Java-Themen 17
S Strings zu Color-Instanzen parsen? Allgemeine Java-Themen 7
C Strings zwischen 2 Zeichen auslesen Allgemeine Java-Themen 7
T Explizite Typkonversation mit Strings Allgemeine Java-Themen 9
R Locale spezifische DateFormat Strings? Allgemeine Java-Themen 3
M Wie kann ich alle System.out Strings in ein log window umleiten? Allgemeine Java-Themen 6
R Java function die Strings escaped, sodass ich sie in Javascript verwenden kann? Allgemeine Java-Themen 4
ruutaiokwu objektreferenz eines strings... Allgemeine Java-Themen 9
data89 [Kurze Frage] Ähnlichkeit zweier Strings ermitteln Allgemeine Java-Themen 19
S bestimmte Strings spliten! Allgemeine Java-Themen 7
M Warum Strings mit equals vergleichen... Allgemeine Java-Themen 6
Daniel_L Suche nach ganzen Wörtern (wholeword) in Strings? Allgemeine Java-Themen 4
A Strings joinen, Standard-Library? Allgemeine Java-Themen 9
Y Mal wieder vergleichen von Strings.[Leider noch ein Problem] Allgemeine Java-Themen 18
data89 Die Größe eines Strings in Byte berechnen? Allgemeine Java-Themen 12
A Auslesen von Strings aus einer xls-Datei Allgemeine Java-Themen 16
G Spezialfrage zu Strings Allgemeine Java-Themen 11
C Textteile aus Strings extrahieren? Allgemeine Java-Themen 6
J Teile eines Strings ersetzen Allgemeine Java-Themen 2
G schnell Strings vergleichen Allgemeine Java-Themen 4
J Name eines Strings durch einen String festlegbar? Allgemeine Java-Themen 2
G Strings zerlegen und substrings auslesen Allgemeine Java-Themen 2
Z Letztes zeichen eines strings löschen Allgemeine Java-Themen 3
V Speicherplatz eines Strings? Allgemeine Java-Themen 12
H MIDlets und Strings Allgemeine Java-Themen 2
C Pixelanzahl eines Strings ermitteln Allgemeine Java-Themen 12
T Strings darf nur Ziffern, +/- haben Allgemeine Java-Themen 9
A Fehler beim Ersetzen eines Strings Allgemeine Java-Themen 3
G byte[] mit Strings füllen Allgemeine Java-Themen 2
H strings in datei verschlüsseln , auslesen mit klartext aber! Allgemeine Java-Themen 2
F Strings in JList ausrichten/links/rechts/mittig Allgemeine Java-Themen 10
M String#equals(), Probleme mit großen Strings? Allgemeine Java-Themen 4
H ein Teil des Strings rausfiltern Allgemeine Java-Themen 8
E Viele if Abfragen auf viele Strings --> Alternative zu if Allgemeine Java-Themen 8
C Strings zu groß um damit zu arbeiten Allgemeine Java-Themen 31
V Lib für Strings suchen und ersetzen (erweitert) Allgemeine Java-Themen 3
P Schnelles Auslesen von Strings für Syntaxhighlighting? Allgemeine Java-Themen 2
X Strings aus einer ArrayList zählen Allgemeine Java-Themen 11
C HASH Algorithmus 2 Strings ergeben das Selbe. Allgemeine Java-Themen 2
G Datei zeilenweise in Strings speichern Allgemeine Java-Themen 36
S Methode zum Zählen von Buchstaben in Strings gesucht Allgemeine Java-Themen 11
I vergleich und zählen von Strings Allgemeine Java-Themen 7
V Strings aus externen Dateien Einlesen (Sudoku) Allgemeine Java-Themen 25

Ähnliche Java Themen

Neue Themen


Oben