Zeichenfolgen in Arrays vergleichen

1207

Aktives Mitglied
Hallo,
ich soll eine Funktion static boolean containsPattern( char[] chars, char[] pattern ) implementieren, die genau dann true zurückgibt, wenn die im Array pattern gerspeicherte Zeichenfolge im Array chars enthalten ist.

Ich habe davor schon ein Methode createCharArrayWithNames() erstellt, die ich als Parameter für chars nehmen soll.

So in meiner containsPattern Funktion schaue ich momentan nur ob die Zeichenfolge von pattern am Anfang von chars ist, aber sobald die gleiche zeichenfolge in chars nicht direkt am anfang steht wird mir false zurück gegeben. Was könnte ich ändern, dass es auch erkennen würde falls irgendwoin der mitte des Arrays die Zeichenfolge von pattern vorhanden ist?

Das ist mein bisheriger Ansatz:

Java:
static char[] createCharArrayWithNames() {
	 
	    char[] name = new char[] {'C','i','n','j','a',';','S','a','v','a','n','a','h'};
	    return name;
	    }
Java:
static boolean containsPattern(char[] chars, char[] pattern){
	 
	     int i = 0;
		 
	     for (int m=0; i<pattern.length ; m++){
		     if (pattern[m] == chars[i])
			     i++;
				 
			 else 
			 { return false;
			 }
		 }
	return true;
	}

Java:
 public static void main(String[] args) {
     char[] pattern = new char[] {'n', 'j', 'a'};
	     System.out.println("containsPattern:" + containsPattern( name, pattern ));

und da wird mir dann leider false ausgegeben, astatt true...
 

rme

Top Contributor
Hallo :)

Die Aufgabe ist schon nicht mehr ganz so einfach, wenn die Lösung in allen Fällen funktionieren soll. Dein momentaner Code fängt am Anfang des Patters an und prüft, ob die Elemente im Array übereinstimmen. Wenn nicht, gibst du direkt false zurück - deine Methode prüft also genaugenommen, ob das Array mit dem Pattern beginnt.

Statt direkt false zurückzugeben, musst du dir etwas anderes überlegen. Was muss denn passieren, wenn du in "Cinja" nach "nja" suchst und das erste Element nicht passt? Kannst du dann schon sagen, dass es insgesamt nicht enthalten sein wird? Falls nicht, wie würdest du dann "manuell" weiter vorgehen? Vielleicht hilft es dir, das erstmal auf Papier zu überlegen :) Aber falls du keinen Ansatz findest, meld dich einfach nochmal.. :)
 

coco07

Bekanntes Mitglied
Vielleicht nicht der beste Code, vielleicht hilft er dir aber...

Als erstes prüfe ich, ob die die Arrays gleich lang sind, wenn nicht, kannst ja gleich "false" aufgeben.
Dann prüfe ich jedes Element einzeln. Sollten sie gleich sein, erhöhe ich einen internen Zähler um 1.
Am Ende überprüfe ich dann, ob der interne Zähler gleich groß wie die Länge des Arrays ist:

Code:
public class Main {


	public static void main(String[] args) {
		System.out.println(containsPattern(new char[] {'a', 'b', 'c'}, new char[] { 'a', 'b', 'c'}));
		
	}
	
	static boolean containsPattern(char[] chars, char[] pattern){
		int zähler=0;
		if(chars.length == pattern.length){
		for(int i=0;i<chars.length;i++){
			if(chars[i] == pattern[i]){
				zähler++;
				continue;
			} else {
				return false;
			}
		}
		if(zähler==chars.length){
			return true;
		} else {
			return false;
		}
		} else {
			return false;
		}
	}

}

Edit: Gerade gelesen, es soll auch gehen, wenn eine Zeichenfolge nur enthalten ist... Ich setz mich nachher mal dran, sorry :(

Liebe Grüße!
 
Zuletzt bearbeitet:

rme

Top Contributor
Gegenbeispiele für die Variante von coco07:
Java:
System.out.println(containsPattern(new char[] {'a',  'b'}, new char[] {'b'})); // false, ist aber true
System.out.println(containsPattern(new char[] {'a',  'b', 'b', 'c'}, new char[] {'b', 'c'})); // false, ist aber true

Der 2. Fall ist nicht so einfach zu lösen
 

1207

Aktives Mitglied
Ich hab jetzt noch was dazu gemacht, was es schafft, dann auch noch die 2. Stelle mit ein zu beziehen, da war dann erst mal die freude groß , bis mir dann aufgefallen ist, dass ab der 3. Stelle wieder nur false rauskommt :D . Natürlich könnte ich das vom Prinzip her die ganze Zeit weiter so schreiben bis alle Stellen von chars beachtete werden, aber das ist bestimm nicht Sinn und Zweck der Aufgabe. Muss man da noch irgendwas mit einer Schleife oder so einbauen???

Java:
 static boolean containsPattern(char[] chars, char[] pattern){
	 
	     int i = 0;
		 
	     for (int m=0; i<pattern.length ; m++){
		     if (pattern[m] == chars[i])
			     i++;
				 
			 else { 
			        if (pattern[m] == chars[i+1]){
			        i= i+2;
					}
					else {return false;
					     }
				  }
		}
			 
	return true;
	}
 

rme

Top Contributor
Ich habe heute leider keine Zeit mehr, aber noch kurz ein Tipp:

Sobald das erste Zeichen des Musters passt, könntest du dir in einer Variable merken, ab welcher Stelle im Array das Muster mit dem Passen angefangen hat. Dann kannst du nämlich im Fall, dass es nicht bis zum Ende passte, danach an der gespeicherten Position + 1 weitermachen, statt false zurückzugeben :)

false gibst du dann erst zurück, wenn die gespeicherte Stelle + Musterlänge außerhalb des Arrays liegt, denn dann kann es ja nicht mehr vorhanden sein. Und true gibst du zurück, falls das Muster bis zum Ende des Musters gelaufen ist.

Viel Erfolg! :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
A Java.util.Arrays Java Basics - Anfänger-Themen 15
T Methodenverknüpfung mit Arrays Java Basics - Anfänger-Themen 4
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
F Eine Zahl mit Arrays vergleichen Java Basics - Anfänger-Themen 7
A 2d Arrays aus txt.file einlesen Java Basics - Anfänger-Themen 16
B Arrays Java Basics - Anfänger-Themen 4
P Arrays "automatisch" erstellen lassen Java Basics - Anfänger-Themen 12
B Nur eine bestimmte Anzahl an Arrays ausgeben Java Basics - Anfänger-Themen 9
H Gemeinsame Schnittmenge zweier Arrays ausgeben Java Basics - Anfänger-Themen 12
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9
A Summe des Arrays pd mit alternativer Schleife Java Basics - Anfänger-Themen 2
S Elemente eines Arrays bei Ausgabe auslassen Java Basics - Anfänger-Themen 2
M Verständnisproblem der Rekursion bei Arrays Java Basics - Anfänger-Themen 8
F Mehrdimensionale Arrays Java Basics - Anfänger-Themen 12
M Arrays in Funktion Kopieren und Bearbeiten Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben