Strings auf Gleichheit prüfen - Aufgabe vom Prof.

  • Themenstarter Gelöschtes Mitglied 67695
  • Beginndatum
G

Gelöschtes Mitglied 67695

Gast
Hallo, ich muss eine Aufgabe von meinen Prof bearbeiten, in der es darum geht Anagramme (= zwei Wörter sind gleich) zu finden.

Ich habe nur eine Frage, an einer Stelle im Code habe ich einen Fehler und in die Lösungen gesehen. Die Lösung gibt mir das vor:

Java:
// Erzeuge eine modifizierbare Kopie von s2
            StringBuffer sb2 = new StringBuffer(s2);

            // Streiche in s2 vorhandene Buchstaben in s1 aus (hier: entfernen)
            for (int i=0; i<s1.length(); i++) {
                int pos = sb2.toString().indexOf(s1.charAt(i));
                if (pos != -1) {
                    sb2.deleteCharAt(pos);
                }
An der Stelle verstehe ich das einsetzen der Int-Variable "pos" nicht. Warum ist die hier notwendig?
 
Zuletzt bearbeitet von einem Moderator:

LimDul

Top Contributor
Was da passiert:
* Es wird das Zeichen an der Stelle i aus s1 gelesen
* Es wird geschaut, an welcher Stelle in sb2 dieses Zeichen auch steht (Stelle = pos)
* Dort wird es dann entfernt

Dafür braucht man sinnvollerweise eine Hilfsvariable - hier pos. Den ein Aufruf von deleteCharAt mit -1 würde eine Exception werfen.

Wenn dir das nicht hilft, versuch mal deine Frage genauer zu stellen, welche Zeile du warum nicht verstehst. Wie es deiner Meinung nach anders gehen würde. Dann kann man dir ggf. besser helfen
 
G

Gelöschtes Mitglied 67695

Gast
Was da passiert:
* Es wird das Zeichen an der Stelle i aus s1 gelesen
* Es wird geschaut, an welcher Stelle in sb2 dieses Zeichen auch steht (Stelle = pos)
* Dort wird es dann entfernt

Dafür braucht man sinnvollerweise eine Hilfsvariable - hier pos. Den ein Aufruf von deleteCharAt mit -1 würde eine Exception werfen.

Wenn dir das nicht hilft, versuch mal deine Frage genauer zu stellen, welche Zeile du warum nicht verstehst. Wie es deiner Meinung nach anders gehen würde. Dann kann man dir ggf. besser helfen
Ich hatte es so Programmiert, weil ich dachte, dass das auch mit i geht, da das ja die Position in dem String ist und beide gleich lang sind.

Java:
if (s1.length() == s2.length()) {
            StringBuffer sb2 = new StringBuffer (s2);
           
            for (int i = 0; i < s1.length(); i++) {
                if (s1.charAt(i) == sb2.toString().charAt(i)) {
                    sb2.deleteCharAt(i);
                }
            }

Deswegen die Frage.
(Also der Code funktioniert bei mir auch nicht, hehe.)
 
Zuletzt bearbeitet von einem Moderator:

LimDul

Top Contributor
Anagramme bestehen ja daraus, dass die Position nicht gleich ist.

Walker und Reklaw sind Anagramme - aber die Position der einzelnen Buchstaben ist nicht gleich.

Sprich, das W steht in ersten String an Position 0 und im zweiten an Position 5.

Hinzu kommt, sobald du ein Zeichen aus sb2 löschst, wird der String kürzer. Das heißt, wenn du in s1 an Stelle 5 bist, ist sb2 vielleicht nur noch 2 Zeichen lang, weil du bereits 4 zeichen gelöscht hast. Und dann versucht alleine der Zugriff auf die Position 5 eine Exception.
 
G

Gelöschtes Mitglied 67695

Gast
Anagramme bestehen ja daraus, dass die Position nicht gleich ist.

Walker und Reklaw sind Anagramme - aber die Position der einzelnen Buchstaben ist nicht gleich.

Sprich, das W steht in ersten String an Position 0 und im zweiten an Position 5.

Hinzu kommt, sobald du ein Zeichen aus sb2 löschst, wird der String kürzer. Das heißt, wenn du in s1 an Stelle 5 bist, ist sb2 vielleicht nur noch 2 Zeichen lang, weil du bereits 4 zeichen gelöscht hast. Und dann versucht alleine der Zugriff auf die Position 5 eine Exception.
Ah, jetzt hab ich es verstanden. Danke!😄
 

berndoa

Top Contributor
Wobei genau genommen bei einem Anagramm das neue Wort nicht mal eine Spiegelung des akten Wortes sein muss (wie hier bei walker und reklaw) (sowas hat auch seinen speziellen namen).
das neue Wort muss nur srichwörtlich haargenau aus den selben Buchstaben wie das alte Wort bestehen, nur neu angeordnet
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H strings auf gleichheit / ungleichheit prüfen wer kann helfen Java Basics - Anfänger-Themen 4
K Gleichheit und Identität von Strings Java Basics - Anfänger-Themen 2
W Gleichzeitiges ersetzen mehrerer Strings Java Basics - Anfänger-Themen 7
R Datentypen Das Verhalten von Strings als Datentypen Java Basics - Anfänger-Themen 7
N Nachkommastellen von Strings Java Basics - Anfänger-Themen 3
T Strings unveränderlich???? Java Basics - Anfänger-Themen 22
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
S Die durchschnittliche Länge der Strings Java Basics - Anfänger-Themen 11
M Operatoren Strings mit Vergleichsoperatoren, funktioniert das? Java Basics - Anfänger-Themen 9
S Variablen Letzte Zeile eines Strings entfernen Java Basics - Anfänger-Themen 1
D Strings aus Excel-Datei einlesen Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
sserio StringBuilder und Strings Java Basics - Anfänger-Themen 8
J Größe eines Strings in Pixel Java Basics - Anfänger-Themen 18
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
B Konkatenieren eines Strings und inkremtierenden Zahl zu einer INT Variablen Java Basics - Anfänger-Themen 7
N Strings verpflechten Java Basics - Anfänger-Themen 4
A 2 Strings vergleichen in einer methode wenn man mit Globalen variablen arbeitet Java Basics - Anfänger-Themen 12
L Strings aneinanderhängen Java Basics - Anfänger-Themen 2
M Strings vergleichen Java Basics - Anfänger-Themen 10
Nerdinfekt BMI Rechner, fehler beim Zurückgeben des Strings? Java Basics - Anfänger-Themen 2
U Problem mit dem initialisieren meines Strings in einer Schleife Java Basics - Anfänger-Themen 5
S 2 Strings mit Equals vergleichen Java Basics - Anfänger-Themen 11
Q Besitzen zwei Strings identische Buchstaben, nur in anderer Reihenfolge? Java Basics - Anfänger-Themen 10
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
C Ternärer Operator mit Strings Java Basics - Anfänger-Themen 3
M Wie kann ich bei int-Variablen im exception handler auf bestimmte Strings reagieren? Java Basics - Anfänger-Themen 5
P Verketten, Aneinanderreihen von Strings Java Basics - Anfänger-Themen 2
M Strings mit gerader und ungerader Länge ausgeben Java Basics - Anfänger-Themen 10
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
W Strings und das parsen Java Basics - Anfänger-Themen 8
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
D Vergleichen von Strings Java Basics - Anfänger-Themen 6
M Konkatenation von zwei Strings Java Basics - Anfänger-Themen 6
J Abbruchbedingung in Schleife/ Untersuchung von Strings Java Basics - Anfänger-Themen 2
S Buchstaben in Großbuchstaben (Strings) Java Basics - Anfänger-Themen 5
X Anagramm mit Strings und Methode Java Basics - Anfänger-Themen 53
P geschachtelte Schleife mit Strings Java Basics - Anfänger-Themen 2
P Strings mit der Axt zerteilen Java Basics - Anfänger-Themen 7
F Alle Zeichenkombinationen eines Strings iterativ herausfinden Java Basics - Anfänger-Themen 26
K Strings hochzählen Java Basics - Anfänger-Themen 20
J Strings untereinander in einer Liste vergleichen Java Basics - Anfänger-Themen 18
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
F Vergleiche mit charAt funktioniert bei Strings nicht, was tun? Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
J Unveränderbarkeit von Strings Java Basics - Anfänger-Themen 3
O Klammerung bei Strings Java Basics - Anfänger-Themen 10
A Liste aus drei Strings erstellen Java Basics - Anfänger-Themen 5
N Zwei Strings mit "==" vergleichen warum TRUE Java Basics - Anfänger-Themen 2
G Teil(e) eines Strings entfernen wenn spezifische Zeichen (< & >) vorkommen Java Basics - Anfänger-Themen 5
D ergebnis.matches("[1-9]?[0-9].[0-9][0-9]?") ein teil eines größeren Strings Java Basics - Anfänger-Themen 12
J Breite eines Strings bestimmen Java Basics - Anfänger-Themen 4
D Zwei Strings sind gleich bei if aber nicht true Java Basics - Anfänger-Themen 2
F JList Elemente mit Strings vergleichen Java Basics - Anfänger-Themen 12
J Strings sind gleich werden aber ungleich ausgewertet Java Basics - Anfänger-Themen 2
N Vergleich von Strings schlägt fehl.. Java Basics - Anfänger-Themen 5
B 4 Strings, Anfangsbuchstaben muss unterschiedlich sein Java Basics - Anfänger-Themen 12
P Strings in String Array schreiben Java Basics - Anfänger-Themen 13
J Input/Output Strings aneinander reihen mit while schleife Java Basics - Anfänger-Themen 25
B mir nur die Gesamtzahl von einzigartigen Strings aus Array ausgeben lassen Java Basics - Anfänger-Themen 5
R Erste Schritte Sicheres einlesen eines Strings Java Basics - Anfänger-Themen 2
F Maximale Länge eines Strings Java Basics - Anfänger-Themen 5
J Best Practice Datum Differenz aus zwei Strings ermitteln Java Basics - Anfänger-Themen 8
Jinnai4 Strings ersetzen Java Basics - Anfänger-Themen 9
R Übergeben eines Array Strings an einen Spinner Java Basics - Anfänger-Themen 4
L Rekursiv zwei Strings vergleichen Java Basics - Anfänger-Themen 3
L Prüfe, ob die im String Array enthaltenen Strings aufsteigend sind. Java Basics - Anfänger-Themen 19
J Algorithmus - Strings auf eigene Reihenfolge miteinander vergleichen Java Basics - Anfänger-Themen 4
DaCrazyJavaExpert Variablen Zahlen aus Strings auslesen Java Basics - Anfänger-Themen 4
C 2 Strings Java Basics - Anfänger-Themen 15
T befehle unterschiedlicher anzahl an strings wiedergeben Java Basics - Anfänger-Themen 2
JavaNewbie2.0 Strings in andere Klassen importieren. Java Basics - Anfänger-Themen 2
D BlueJ Java: Strings voneinander trennen Java Basics - Anfänger-Themen 11
javaerd Wie kann ich Brute Force Methode mit Strings erweitern Java Basics - Anfänger-Themen 1
R Erste Schritte Strings "einrücken" Java Basics - Anfänger-Themen 3
Yamie ArrayList<Object> als Liste von Strings ausgeben? Java Basics - Anfänger-Themen 15
B gemeinsames Vorkommen der charactere von 2 Strings als String zurückgeben Java Basics - Anfänger-Themen 5
R Teilinhalt eines Strings testen Java Basics - Anfänger-Themen 10
H Erste Schritte JTree: Instanzen einer Klasse speichern oder Namen/Strings... Java Basics - Anfänger-Themen 4
L Werte von Strings ? Java Basics - Anfänger-Themen 1
L Strings und Arrays - Expand Java Basics - Anfänger-Themen 12
I Schachbrett aus beliebigen Strings erstellen Java Basics - Anfänger-Themen 3
Syncopated Pandemonium Verketten von Strings funktioniert nicht Java Basics - Anfänger-Themen 4
F Wahrscheinlichkeit von Strings Java Basics - Anfänger-Themen 3
MiMa Splitten eines Strings Java Basics - Anfänger-Themen 5
T Hashfunktion für Strings Java Basics - Anfänger-Themen 3
C Zeilenumbruch für langes Strings Java Basics - Anfänger-Themen 2
J Variablen Strings mit Zeilenumbrüchen in neues Array Element Java Basics - Anfänger-Themen 1
T Datentypen compareTo() u. equals() bei Strings Java Basics - Anfänger-Themen 3
H Strings vergleichen & sortieren Java Basics - Anfänger-Themen 20
H Erste Schritte Längstes Wort eines Strings herausfinden Java Basics - Anfänger-Themen 7
D Problem beim umwandeln eines Strings in eine Dzezimalzahl Java Basics - Anfänger-Themen 6
G Strings mit Scanner (nextLine) einlesen Java Basics - Anfänger-Themen 7
T Strings ersetzen mit \ Java Basics - Anfänger-Themen 10
K Strings bearbeiten Java Basics - Anfänger-Themen 14
N Bestimmte Zeichen eines Strings umwandeln Java Basics - Anfänger-Themen 4
L Java Strings Buchstaben vertauschen Java Basics - Anfänger-Themen 4
L Strings in einem JOptionPane farbig Java Basics - Anfänger-Themen 2
A Wie bekomme ich zwei Strings in eine ArrayList Java Basics - Anfänger-Themen 4
C Chars eines Strings mit for schleife rückwärts auslesen Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben