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.

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 erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

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