FiLiPo Geschrieben 21. September 2005 Geschrieben 21. September 2005 Hallo zusammen! Ich habe folgendes Problem: Zwischen zwei Strings möchte ich vergleichen, ob ein INSERT oder REMOVE von Zeichen stattgefunden hat. Ich habe das Problem im Moment nur annäherungsweise gelöst, indem ich den alten Text wortweise mit dem neuen vergleiche. Wenn ein Wort nicht mehr vorkommt, hat ein REMOVE stattgefunden, wenn im neuen eines vorkommt, das nicht im alten enthalten ist, ein INSERT. Aber das ist noch nicht optimal, hierfür müsste man beide Strings zeichenweise vergleichen. Gibt es für dieses Problem schon eine Lösung? Viele Grüße Philipp
geloescht_Newlukai Geschrieben 21. September 2005 Geschrieben 21. September 2005 Wenn Du Dir sicher gehen kannst, daß nur eine der beiden Operationen statt gefunden hat, dann vergleiche doch einfach die Länge?!? Ansonsten wirste wohl kaum an einem zeichenweisen Vergleich vorbei kommen.
FiLiPo Geschrieben 21. September 2005 Autor Geschrieben 21. September 2005 Dieser zeichenweise Vergleich ist auf jeden Fall notwendig. Die Frage ist nur, ob es da schon eine fertige Lösung gibt, das Problem ist ja nicht neu. Weil einen Algorithmus selber zu entwickeln... na Mahlzeit Bei dem ganzen geht es um das edit transscript / distance problem.
geloescht_Newlukai Geschrieben 21. September 2005 Geschrieben 21. September 2005 Ich wüßte nicht, daß das SDK sowas mitbringt. Vielleicht gibt es ja eine Bibliothek dazu ...
mkScheller Geschrieben 22. September 2005 Geschrieben 22. September 2005 na wenn man nur schauen soll, ob etwas verändert wurde, dann dürfte diser algorhythmus ja nicht allzu schwer sein. wenn man nur einzelne wörter vergleichen muss, ich stell mir das nicht schwer vor, vielleicht gibts da ne adäquate lösung unter zuhilfenahme von pattern und matchern
etreu Geschrieben 22. September 2005 Geschrieben 22. September 2005 Du kannst doch wie schon beschreiben erst mal die Länge vergleichen. Dann kannst du mittels String.compareTo(anotherString) weitermachen. Alternativ kannst du dir auch ein eigenes kleines diff-Tool bauen für deine Strings: Du nimmst Token und vergleichst diese miteinander. Nur mal so ne Frage: Das ist doch ein NP-Problem, oder?
ExAzubi Geschrieben 23. September 2005 Geschrieben 23. September 2005 So schwer ist der allgorythmus auch nicht. String str1 = "TEST1";//Urspr. String str2 = "TEST2";//Neuer char[] chr1; char[] chr2; chr1 = str1.toCharArray(); chr2 = str2.toCharArray(); if(chr1.length<chr2.length){ //insert } else if(chr1.length>chr2.length){ //removed } else if(chr1.length==chr2.length){ for (int i = 0; i < chr1.length; i++) { if(chr1[i]!=chr2[i]){ //changed/removed and insert } } } Das stimmt so in etwa, aber auch nicht ganz Sauber.
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden