Zum Inhalt springen

Stringvergleich


Empfohlene Beiträge

Geschrieben

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

Geschrieben

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.

Geschrieben

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

Geschrieben

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?

Geschrieben

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.

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...