Zum Inhalt springen

Stringvergleich


FiLiPo

Empfohlene Beiträge

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

Link zu diesem Kommentar
Auf anderen Seiten teilen

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?

Link zu diesem Kommentar
Auf anderen Seiten teilen

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.

Link zu diesem Kommentar
Auf anderen Seiten teilen

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...