Besitzen zwei Strings identische Buchstaben, nur in anderer Reihenfolge?

Qualli

Mitglied
Hallo Leute,

Ich hab folgende Frage:

angenommen ich habe einen String, nennen wir ihn
Java:
String word = "level";
und eine Methode
Java:
public boolean consistsWord (String s "LvEel"){}
. Wie kann ich herausfinden, ob man aus String s, String word formen kann, true oder false soll am Ende herrauskommen.

"Level" und "LvEel", sollen nur Platzhalter Worte sein, man könnte also jedes beliebige Wort einsetzen und die Methode überprüft dann; ob aus
Java:
String s
,
Java:
String word
entstehen könnte.

Meine Idee war es, erstmal alle Buchstaben von
Java:
String s
und
Java:
String word
in Kleinbuchstaben zu ändern und möglichen Whitespace zu entfernen (wenn bespielsweise Wörter wie
Java:
String s "Lv Eel";
auftreten). Dann wollte ich die Länge der beiden Strings vergleichen, sind sie gleich, geht's weiter, wenn nicht wird false zurückgegeben. Soweit alles klar, aber was mach ich dann. Ich müsste ja theoretisch die einzelnen Buchstaben zählen und wenn die Anzahl bei beider Strings übereinstimmt (sprich "level" = 2*l, 2*e, 1*v --> "LvEel" = 2*l, 2*e, 1*v) wird true ausgegeben, wenn nicht false. Leider hab ich absolut keine Ahnung, wie ich das ausgeben soll geschweige denn, ob dieser Lösungsansatz der Richtige ist.

Ich sitze seit drei Wochen in einem Java-Kurs für Anfänger, somit dürfte die Lösung ja eigentlich gar nicht so schwer sein, wahrscheinlich haperts bei mir noch ein bisschen am Grundverständnis. Also wenn jemand einen leichteren Lösungsansatz findet oder mir wenigstens erklären kann, was ich hier zu tun habe, würde mir das sehr helfen.

MfG Flori
 

temi

Top Contributor
ob dieser Lösungsansatz der Richtige ist.
"Den" richtigen Lösungsansatz gibt es meist nicht, weil es fast immer mehrere Lösungen gibt, aber so wie beschrieben, könnte man es machen.

Du könntest auch, nach Kleinbuchstaben und Whitespace, die Buchstaben der beiden Strings sortieren und die sich daraus ergebenden Strings vergleichen.
 

Qualli

Mitglied
"Den" richtigen Lösungsansatz gibt es meist nicht, weil es fast immer mehrere Lösungen gibt, aber so wie beschrieben, könnte man es machen.

Du könntest auch, nach Kleinbuchstaben und Whitespace, die Buchstaben der beiden Strings sortieren und die sich daraus ergebenden Strings vergleichen.


Ok gut Buchstaben zu sortieren hört sich einfacher an, als einzelne Buchstaben zu zählen und zu vergleichen.

Herauskommen müsste dann ja ein Code der folgendes macht:

An Position 0 im String word steht l ---> suche l in String s und setze l an Position 0 usw....... bis das Wort rauskommen; falls nicht dann false.

Ich bin mir grad nicht sicher charAt() gibt doch dann den Index an oder?

also
Java:
        for(int i = 0; i < word.length(); i++){
            if (sentence1.charAt(i) ......}

Aber wie finde ich dann den Buchstaben in String s und setze ihn dann an Position 0
 

White_Fox

Top Contributor
Du kannst dir das Sortieren auch sparen, und stattdessen erstmal alles in Groß- ODER Kleinbuchstaben konvertieren.

Anschließend castest du den String in ein Char-Array und bildest die Summe aller Werte im Array. Enthalten beide Strings die gleichen Buchstaben in gleicher Anzahl (aber beliebiger Reihenfolge), muß die Summe in beiden Fällen gleich sein.
 

Qualli

Mitglied
Du kannst dir das Sortieren auch sparen, und stattdessen erstmal alles in Groß- ODER Kleinbuchstaben konvertieren.

Anschließend castest du den String in ein Char-Array und bildest die Summe aller Werte im Array. Enthalten beide Strings die gleichen Buchstaben in gleicher Anzahl (aber beliebiger Reihenfolge), muß die Summe in beiden Fällen gleich sein.

Ok hab ich zwar noch nie gemacht, aber ich werd's mal versuchen 😅
 

httpdigest

Top Contributor
und bildest die Summe aller Werte im Array. Enthalten beide Strings die gleichen Buchstaben in gleicher Anzahl (aber beliebiger Reihenfolge), muß die Summe in beiden Fällen gleich sein.
Die Implikation gilt aber nur in eine Richtung (ist also nur eine hinreichende Bedingung, keine notwendige). Du hast schon Recht damit, dass, wenn beide Strings diegleichen Buchstaben (egal, in welcher Reihenfolge) enthalten, dann haben sie auch beide dieselbe Summe (über die Codes der Buchstaben). Allerdings können zwei völlig unterschiedliche Strings (mit derselben Anzahl an Zeichen) auch dieselbe Summe bilden. Oder mit anderen Worten: Nur, weil die Summe dieselbe ist, müssen die Strings nicht diegleichen Buchstaben enthalten haben.
Beispiel (hypothetische ASCII-Werte): {10, 2} != {6, 6}
 

Qualli

Mitglied
Die Implikation gilt aber nur in eine Richtung (ist also nur eine hinreichende Bedingung, keine notwendige). Du hast schon Recht damit, dass, wenn beide Strings diegleichen Buchstaben (egal, in welcher Reihenfolge) enthalten, dann haben sie auch beide dieselbe Summe (über die Codes der Buchstaben). Allerdings können zwei völlig unterschiedliche Strings (mit derselben Anzahl an Zeichen) auch dieselbe Summe bilden. Oder mit anderen Worten: Nur, weil die Summe dieselbe ist, müssen die Strings nicht diegleichen Buchstaben enthalten haben.
Beispiel (hypothetische ASCII-Werte): {10, 2} != {6, 6}


Mhhh also soll ich lieber etwas anderes ausprobieren, als den String zu casten und die Summen zu vergleichen?

war mir bei meinem Code diesbezüglich eh total unsicher, ob das überhaupt möglich ist, was ich da mache.
 

mihe7

Top Contributor
@Qualli Du hattest doch einen Lösungsansatz. Setz doch den einfach mal um (treten dabei für Dich unlösbare Probleme auf, kannst Du Dir da durchaus helfen lassen). Das hat verschiedene Vorteile, unter anderem:
  1. Es ist Dein Ansatz, den hast Du entwickelt und nicht irgendwo abgekupfert.
  2. Ggf. werden Dir mögliche Schwächen des Ansatzes klar, ansonsten kann man die auch aufzeigen. Vielleicht fallen Dir dann plötzlich auch neue, bessere/schönere Lösungsansätze ein.
  3. Sortieralgorithmen sind jetzt nicht unbedingt etwas, das man lernt, wenn man gerade mit dem Programmieren begonnen hat.
  4. Die anderen zahlreichen Möglichkeiten, die es sonst noch gibt, laufen Dir nicht davon.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Aus wieviel Klassen darf in Java eine (Programm)besitzen? Java Basics - Anfänger-Themen 21
Torschti Eingabe von Dezimalzahlen (bis zu zwei Kommastellen) Java Basics - Anfänger-Themen 11
A 1 Leerzeichen durch zwei Leerzeichen ersetzen Java Basics - Anfänger-Themen 4
K Warum wird mir hier nach dem ersten Durchlauf zwei mal "welchen Datentyp wollen sie übergeben?" ausgegeben ? Java Basics - Anfänger-Themen 1
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8
krgewb Double mit zwei Nachkommastellen Java Basics - Anfänger-Themen 2
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
berserkerdq2 Habe zwei exceptions, welche ist ein Kommunikationsfehler und welche ein Ausgabefehler? Java Basics - Anfänger-Themen 4
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
B Erste Schritte Bisektion mit zwei Funktionen? Java Basics - Anfänger-Themen 1
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
A Java-XSSFBook: zwei Sheets mergen Java Basics - Anfänger-Themen 5
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
J Speichern von zwei Variablen durch Auslesen aus einem Numberfield Java Basics - Anfänger-Themen 2
D Zwei verschiedene Intellij Projekte, wie benutze ich wechselseitig objekte Java Basics - Anfänger-Themen 8
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
K mit <<1 kann man mal 2 machen, mit >>2 geteilt durch zwei und was bewirkt <<<1 und >>>1? Java Basics - Anfänger-Themen 5
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
F Abstand zwischen zwei Objekten berechnen wie? Java Basics - Anfänger-Themen 1
M Wie kann ich ein Array in zwei Hälften aufteilen? Java Basics - Anfänger-Themen 12
S Längster Pfad zwischen zwei Vertices in einem Graph Java Basics - Anfänger-Themen 3
S Aktuell beste Methode um zwei Bilder zu vergleichen..? Java Basics - Anfänger-Themen 1
A Zwei XML-Dateien Mergen Java Basics - Anfänger-Themen 14
U Erste Schritte nextGaussian zwischen zwei Werten Java Basics - Anfänger-Themen 19
S Multiplikation von zwei Labels Java Basics - Anfänger-Themen 7
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
Düsseldorf2002 Datentypen Zwei dimensionale LinkedList Java Basics - Anfänger-Themen 8
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
J Zwei Objekte vergleichen Java Basics - Anfänger-Themen 8
X Zwei Dimensionales Array prüfen Java Basics - Anfänger-Themen 1
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
E Wie gebe ich alle Daten zwischen zwei Zeitpunkten aus? Java Basics - Anfänger-Themen 2
pkm Regexproblem - Wie kann ich zwei oder mehr beliebige Zeichen matchen? Java Basics - Anfänger-Themen 7
A Wieso bekomme ich hier zwei unterschiedliche Ausgaben? Java Basics - Anfänger-Themen 6
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
R Methode zwei Sortierkriterien der Klasse Comparator übergeben Java Basics - Anfänger-Themen 4
B Collections.sort mit zwei Bedingungen? Java Basics - Anfänger-Themen 4
X Textdatei: zwei-zeilenweise gleiche Zeilen rausschmeißen Java Basics - Anfänger-Themen 21
M Konkatenation von zwei Strings Java Basics - Anfänger-Themen 6
J Problem beim vergleich von zwei Integer Java Basics - Anfänger-Themen 3
D Input/Output Input von zwei Koordinaten validieren und anschließend Werte speichern Java Basics - Anfänger-Themen 7
L Zwei sortierte Subarrays mit gleicher Länge zusammenfügen Java Basics - Anfänger-Themen 2
F Zwei Dimensionles Array Java Basics - Anfänger-Themen 21
I Alle Elemente von zwei Listen vergleichen Java Basics - Anfänger-Themen 1
J Inhalte von zwei Arrays vertauschen?! Java Basics - Anfänger-Themen 6
O zwei Arrays nach Werten durchsuchen und zusammenfügen Java Basics - Anfänger-Themen 3
A Wie zwei zahlen in einer Variable speichern? Java Basics - Anfänger-Themen 7
N Zwei Daten (Datum) miteinander vergleichen, abspeichern, laden Java Basics - Anfänger-Themen 4
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
B Relativen Anteil von zwei Datümer auf Monatsebene umrechnen Java Basics - Anfänger-Themen 130
W Zwei Programme sollen auf eine Klasse zugreifen Java Basics - Anfänger-Themen 18
B Rückgabe von zwei Werten: String und double Java Basics - Anfänger-Themen 14
J Zwei Klassen die sich gegenseitig referenzieren - Bad practice? Java Basics - Anfänger-Themen 4
B Anzahl von Stunden / Tage von zwei Datumswerten ermitteln Java Basics - Anfänger-Themen 1
L Erste Schritte Elemente zwei Schlangen vergleichen Java Basics - Anfänger-Themen 14
N Zwei Strings mit "==" vergleichen warum TRUE Java Basics - Anfänger-Themen 2
D Input/Output InputDialog mit zwei Inputfeldern? Java Basics - Anfänger-Themen 4
D Funktion zwei Arraylisten zu verleichen ob gleich funktioniert nicht Java Basics - Anfänger-Themen 26
S Daten aus zwei Verschiedenen Tabellen in eine ArrayListe Java Basics - Anfänger-Themen 4
D Zwei Strings sind gleich bei if aber nicht true Java Basics - Anfänger-Themen 2
E Best Practice Jar-file mit zwei Klassen und externer Bibliothek über Konsole erzeugen Java Basics - Anfänger-Themen 13
J Logging erzeugt zwei dateien.... Java Basics - Anfänger-Themen 7
S zwei-dimensionales Array Java Basics - Anfänger-Themen 20
R Zwei Attribute gleichzeitig ausgeben Java Basics - Anfänger-Themen 12
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
T Classpath Zwei gleiche Dateinamen in verschiedenen Projekten möglich? Java Basics - Anfänger-Themen 13
H Bubblesort-Zwei Integer auf Dekade vergleichen. Java Basics - Anfänger-Themen 6
M Wie erzeuge ich die Differenz von zwei Daten in Stunden?? Java Basics - Anfänger-Themen 2
L Den Winkel zwischen zwei Vektoren berechnen! Java Basics - Anfänger-Themen 2
jaleda100 KeyCode – zwei Tasten gleichzeitig Java Basics - Anfänger-Themen 2
M Methoden Zwei Methoden in einem Program laufen lassen...aber wie? Java Basics - Anfänger-Themen 2
M Methoden zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M For-Schleife durch zwei versch. Variablen begrenzen Java Basics - Anfänger-Themen 27
B Erste Schritte Problem bei der Verknüpfung von zwei klassen Java Basics - Anfänger-Themen 8
J Methoden Zwei Methoden die fast das gleiche tun organisieren Java Basics - Anfänger-Themen 3
Bluedaishi der Monat zwischen zwei Datumsangaben Java Basics - Anfänger-Themen 15
J Best Practice Datum Differenz aus zwei Strings ermitteln Java Basics - Anfänger-Themen 8
J Ein Objekt and eine Methode übergeben zwei Schreibweisen? Java Basics - Anfänger-Themen 6
R Threads Pause zwischen zwei Schleifen Java Basics - Anfänger-Themen 1
Aprendiendo Zwei Fragen und ein geerbtes "protected"-Attribut Java Basics - Anfänger-Themen 2
S Parameterübergabe zwischen zwei Programme Java Basics - Anfänger-Themen 4
L Rekursiv zwei Strings vergleichen Java Basics - Anfänger-Themen 3
L Classpath Zwei Bibliotheken enthalten gleiche .class Datei Java Basics - Anfänger-Themen 6
S OOP Zwei JSlider in einer Klasse Java Basics - Anfänger-Themen 2
P Aus einem Array zwei Arrays machen Java Basics - Anfänger-Themen 3
ArkHeat Erste Schritte Zwei 2-dimensionale Matritzen addieren Java Basics - Anfänger-Themen 0
S Erste Schritte Zwischen zwei Punkten ein Minimumpkt./Maxima finden Java Basics - Anfänger-Themen 1
T OOP Zwei Klassen Testen (Arrary Iterieren) Java Basics - Anfänger-Themen 6
E Eine Instanzvariable und zwei Objekte Java Basics - Anfänger-Themen 14
S Durchschnitt berechnen aus zwei Textfeldern Java Basics - Anfänger-Themen 21
K Zwei Fragen zu Graphics/Graphics2D Java Basics - Anfänger-Themen 5
P Verbindung von Zwei Kreisen löschen ! Java Basics - Anfänger-Themen 6
J Zwei String-Variabeln vergleichen Java Basics - Anfänger-Themen 5
F Vererbung in zwei Richtungen? Java Basics - Anfänger-Themen 14
J Hilfe beim "Verknüpfen" von zwei Klasse Java Basics - Anfänger-Themen 15
N Mit der gleichen BlockingQueue in zwei Klassen arbeiten Java Basics - Anfänger-Themen 12
S Methoden Vergleichen von zwei Listen in der Geschwindigkeit von O(n+m) Java Basics - Anfänger-Themen 32

Ähnliche Java Themen

Neue Themen


Oben