String-Interpolationssuche?

Status
Nicht offen für weitere Antworten.

bröggle

Bekanntes Mitglied
Hi,
*hust* (ich muss erstmal den staub von meinem account entfernen)

und zwar habe ich das problem, dass ich einen algo für die interpolierte Suche erstellen soll.
Soweit kein problem (im inet gibt es ja genügend Beispiele für die interpolierte Suche für Zahlen), aber ich 'muss'/möchte nach einem String suchen.

d.h. einen String aus einem Stringarray raussuchen.

->Problem dabei die neuen teilbereiche zu berechnen.

so wie hier: http://de.wikipedia.org/wiki/Interpolationssuche geht es eben nicht (ich kann ja nicht mit 'foo' malnehmen)


Meine Fragen also:
Geht eine Interpolierte Suche überhaupt mit Strings (muss eigentlich)
2.Wenn ja wie, bzw hat jemand ein Beispiel?bzw kann mir jemand erklären wie ich die neuen teilbereiche rausbekomme?
Denn sowas wie indexOf werde ich ja wohl nicht nehmen dürfen


Danke schonmal
^-^
 
S

stev.glasow

Gast
Ne größer weil abc mehr Zeichen hat. Auf'n Schlag wüsste ich aber auch nix anderes ???:L
 

bröggle

Bekanntes Mitglied
hmm, könnte man dann nicht
den sting mit vielen Z (letztes in sortierung) füllen, sodass zumindest die Stellen zahl gleich wäre?

ZZZZabc <
ZZZZZzz

würde ja wieder stimmen.
aber welche hashfunktion kann das so machen?
bzw welche liefert eine entsprechende Zahl zurück
 
S

stev.glasow

Gast
hab doch was zusammen gefriemelt bekommen, hab den Code von Wikipedia etwas angepasst:
Code:
public static int interpolierteSuche(String schlüssel, String daten[])
	 {
	   int links = 0;                  // linke Teilfeldbegrenzung 
	   int rechts = daten.length - 1;  // rechte Teilfeldbegrenzung
	   int versch;                     // Anzahl verschiedener Elemente
	   int pos;                        // aktuelle Teilungsposition

	   // solange der Schlüssel im Bereich liegt (andernfalls ist das gesuchte 
	   // Element nicht vorhanden)
	   while( schlüssel.compareTo(daten[links]) >= 0 && schlüssel.compareTo(daten[rechts]) <= 0 ){
	     // Aktualisierung der Anzahl der verschiedenen Elemente
	     versch = daten[rechts].compareTo(daten[links]);
	        
	     // Berechnung der neuen interpolierten Teilungsposition 
	     pos = links + (int)(((double)rechts - links) * (schlüssel.compareTo(daten[links]))
	           / versch);
	     
	     if( schlüssel.compareTo(daten[pos]) > 0)             // rechtes Teilintervall 
	       links = pos + 1;                       // daten[pos] bereits überprüft
	     else if( schlüssel.compareTo(daten[pos])  < 0 )       // linkes Teilintervall
	       rechts = pos - 1;                      // daten[pos] bereits überprüft
	     else                                     // Element gefunden
	       return pos;                            // Position zurückgeben
	   }
	        
	   return -1;                                 // Element nicht gefunden
	 }
 
S

stev.glasow

Gast
Scheiße geht doch nicht, nur wenn die Strings nur aus Zahlen bestehen, was dir ja gar nix bringt.
[edit] Und dann auch nicht richtig, den Code kannst du in die Tonne kloppen.
 

bröggle

Bekanntes Mitglied
hehe, trotzdem danke für deine mühe;-)

Die Hashcode-Methode ist ansich eine ganz gute Ideejeoch funktioniert das nur bis zu einer bestimmten stringlänge... z.b. bei 10Stellen gibt es - Zahlen und das ganze hat sich erledigt:

CCCCCCCCCD 997603809

DDDDDDDDDE 1653533313

EEEEEEEEEF -1985504479

FFFFFFFFFG -1329574975

GGGGGGGGGH -673645471
 
S

stev.glasow

Gast
Du mein Code oben geht doch, hatte im Test einen Fehler, hatte einen Array übergeben der nicht sortiert war.
 
S

stev.glasow

Gast
ich hab einfach die a - b durch a.compareTo(b) ersetzt und die a >= b durch a.compareTo(b) >= 0 usw.
Klar was das soll?
 

bröggle

Bekanntes Mitglied
juhuhuhuhu geht!


;-)
eigentlich wars ganz logisch, aber da fehlts mir noch ein wenig an erfahrung ;-)

Naja vielleicht wirds ja dann im Studium besser


Danke


p.s.: wünscht mir glück für den 28.4, 2.5 und 12.5 (ABI)
 
O

ohNein

Gast
stevg hat gesagt.:
hab doch was zusammen gefriemelt bekommen, hab den Code von Wikipedia etwas angepasst:
Code:
public static int interpolierteSuche(String schlüssel, String daten[])
	 {
	   int links = 0;                  // linke Teilfeldbegrenzung 
	   int rechts = daten.length - 1;  // rechte Teilfeldbegrenzung
	   int versch;                     // Anzahl verschiedener Elemente
	   int pos;                        // aktuelle Teilungsposition

	   // solange der Schlüssel im Bereich liegt (andernfalls ist das gesuchte 
	   // Element nicht vorhanden)
	   while( schlüssel.compareTo(daten[links]) >= 0 && schlüssel.compareTo(daten[rechts]) <= 0 ){
	     // Aktualisierung der Anzahl der verschiedenen Elemente
	     versch = daten[rechts].compareTo(daten[links]);
	        
	     // Berechnung der neuen interpolierten Teilungsposition 
	     pos = links + (int)(((double)rechts - links) * (schlüssel.compareTo(daten[links]))
	           / versch);
	     
	     if( schlüssel.compareTo(daten[pos]) > 0)             // rechtes Teilintervall 
	       links = pos + 1;                       // daten[pos] bereits überprüft
	     else if( schlüssel.compareTo(daten[pos])  < 0 )       // linkes Teilintervall
	       rechts = pos - 1;                      // daten[pos] bereits überprüft
	     else                                     // Element gefunden
	       return pos;                            // Position zurückgeben
	   }
	        
	   return -1;                                 // Element nicht gefunden
	 }

Nur das die ganze Sache nicht das hält was es verspricht.
Es soll ja eine günstige position für das suchen gefunden werden.
CompareTo liefert aber nur -1,0,1 und bringt somit nicht viel bei der Berechnung der Position
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
C EML Email Text in String wandeln Allgemeine Java-Themen 11
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
JAnruVA Datentypen Berechneten String-Wert in Double umwandeln um weiter zu rechnen Allgemeine Java-Themen 7
M String Allgemeine Java-Themen 10
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
O String in Long Hexerdezimal umwandel Allgemeine Java-Themen 14
N String vergleichen. Allgemeine Java-Themen 27
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
SaschaMeyer Arbeitet String.split falsch? Allgemeine Java-Themen 4
M Switches ohne String Allgemeine Java-Themen 18
AmsananKING String Iteration Allgemeine Java-Themen 5
S Shuffle String aus if-clause Allgemeine Java-Themen 11
Besset Variablen Ist String = "" + int inordnung? Allgemeine Java-Themen 6
M Map <Long, String> zu Map<String, Long> Allgemeine Java-Themen 9
I String Encoding Verständnisproblem Allgemeine Java-Themen 22
N Prüfen, ob ein String 2x das selbe Zeichen hat Allgemeine Java-Themen 10
SaftigMelo Bug Fixen von String-spliten Allgemeine Java-Themen 8
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
YohnsonM String - Aufteilung und Nutzung einzelner Chars Allgemeine Java-Themen 7
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
S String umbenennen: wie? Allgemeine Java-Themen 4
x46 String Format Fehler Allgemeine Java-Themen 2
S ISO 8601 -> getter / setter String Allgemeine Java-Themen 3
L String zu repräsentativen Wert Allgemeine Java-Themen 0
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
L regex ganzer string? Allgemeine Java-Themen 2
L Ist ein string ein erlaubter variabel name? Allgemeine Java-Themen 2
Z JNA Cpp-DLL String Verwendung Allgemeine Java-Themen 2
A String auf Zahlen überprüfen Allgemeine Java-Themen 5
N String Array Eingabe Allgemeine Java-Themen 6
MiMa Datum von String zu LocalDateTime Allgemeine Java-Themen 8
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
R char aus String entfernen Allgemeine Java-Themen 10
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Ini Text aus String parsen Allgemeine Java-Themen 1
T String-Manipulation beim Ablauf in Eclipse und als JAR-File Allgemeine Java-Themen 8
M String lässt sich nicht Zusammenfügen Allgemeine Java-Themen 10
Drachenbauer Wie kann ich das Wort "concrete" in einem String durch ein anderes Wort ersetzen lassen? Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
R Variablen String mit split-Funktion aufteilen Allgemeine Java-Themen 7
F Datei in String-Array einlesen Allgemeine Java-Themen 8
S Marker aus String ermitteln Allgemeine Java-Themen 5
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
M Bei String.format ein Komma statt einem Punkt ausgeben lassen Allgemeine Java-Themen 1
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J String - Vergleiche Allgemeine Java-Themen 7
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
G CSV in String Allgemeine Java-Themen 7
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
D Erste Schritte Fehler mit negativen und 0 Zahlen im String Allgemeine Java-Themen 6
Xge Replace x Zeichen aus String Allgemeine Java-Themen 2
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
F In String 2 Buchstaben vertauschen Allgemeine Java-Themen 2
J Class Decompile als String (Procyon) Allgemeine Java-Themen 2
I Datentypen String in class sicher verwahren Allgemeine Java-Themen 17
J Falls der String ein "X" beinhaltet Allgemeine Java-Themen 2
T String mehrere Worte Allgemeine Java-Themen 2
D String Groß-/Kleinschreibung Allgemeine Java-Themen 2
D String und Klassenvariable Allgemeine Java-Themen 6
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
C String in Objektnamen umwandeln Allgemeine Java-Themen 3
E Variablen Aus .txt ausgelesener string mit if() überprüfen? Allgemeine Java-Themen 2
L String-Schema-Aufspaltung Allgemeine Java-Themen 2
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
L String splitten und multiplizeren Allgemeine Java-Themen 10
G String mit umbekannter länge splitten. Allgemeine Java-Themen 2
S Einzigartigen String in Datenbank finden und löschen Allgemeine Java-Themen 23
A Byte zu String Allgemeine Java-Themen 4
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
T Komplexitätsoptimierung String vergleich Allgemeine Java-Themen 4
heinz ketchup String im JLabel ausgeben und erneuern Allgemeine Java-Themen 6
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
L Decrypt String Allgemeine Java-Themen 1
X Variablen AtmicLong größer als String ? Allgemeine Java-Themen 4
S String literal und Referenzvariablen Allgemeine Java-Themen 6
J Datentypen Absätze mit String im Word Dokument Allgemeine Java-Themen 3
D "Paste" String doppelt Allgemeine Java-Themen 14
E String Frage Allgemeine Java-Themen 9
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
D JSON to String Allgemeine Java-Themen 31
M String automatisch in nächste Zeile umbrechen (Graphics) Allgemeine Java-Themen 6
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
T Swing Font String Pixellänge Allgemeine Java-Themen 1
G Substrings in einen String zusammenfassen Allgemeine Java-Themen 5
Tommy Nightmare String.replaceAll(...) fehlerhaft? Allgemeine Java-Themen 3
L String auf zahlenwert prüfen Allgemeine Java-Themen 13
U OOP Warum kann ich aus meiner Methode keinen String auslesen Allgemeine Java-Themen 4
L 2-Dimensionaler String: Zahlen verschieben Allgemeine Java-Themen 10

Ähnliche Java Themen

Neue Themen


Oben