Methoden Char-Arrays auf aufeinanderfolgende Elemente vergleichen!

Aimxvega

Neues Mitglied
Hallo liebes Forum,
Ich bin gerade an der Klausurvorbereitung dran und stehe vor einem Problem. Ich soll zu dem folgenden Methodenkopf:
"boolean c(char [] p, char [] q, int n)"
einen Methodenrumpf erstellen, so dass die Methode 'c' genau dann den Wert 'true' liefert, wenn 'n' aufeinander folgende Elemente von 'p' gleich n aufeinander folgenden Elementen von 'q' sind.
Dabei ist es egal ab welchen Indizes die Elemente stehen, solange die Reihenfolge richtig ist.

Beispiel:
char a [] = new char [] {'F', 'i', 'n', 'g', 'e', 'r'}
char b [] = new char [] {'W', 'e', 'i', 'n', 'g', 'l', 'a', 's'}
Für n = 3 sollte die Methode den Rückgabewert 'true' liefern.

Meine Idee war es, erst abzufragen ob die Arrays = null sind oder ob die Länge der Arrays kleiner ist als die Integer Zahl 'n' --> 'false'.
Daraufhin wollte ich die Arrays mit 2 'for-Schleifen' durchlaufen und einen Counter hochzählen lassen. Leider funktioniert das nicht, habt ihr mir nützliche Tipps als Anfänger?
 

Aimxvega

Neues Mitglied
Java:
static boolean c(char[] p, char[] q, int n) {
        int counter = 1;
        if (p == null || q == null) {
            return false;
        }
        else if (p.length < n || q.length < n) {
            return false;
        }
        for (int i = 0; i < p.length; i++) {
            for (int j = 0; j < q.length; j++) {
                if (p[i] == q[j] && q[j + n] < q.length) {
                    counter++;
                    for (int k = 1; k <= n; k++) {
                        if (p[i + (k/n * n)] == q[j + (k/n * n)]) {
                            counter++;
                        }
                    }
                }   
            }
        }
        if (counter == n) {
            return true;
        }
        return false;
    }

Wie auch immer man diese gut formatierten Quellcodes hier rein bekommt :/?
 
Zuletzt bearbeitet von einem Moderator:

Meniskusschaden

Top Contributor
Grundsätzlich ist das schon die richtige Idee. Es gibt aber noch einige Fehler. Beispielsweise prüft die Bedingung
Java:
q[j + n] < q.length
wohl nicht das, was du vermulich bezweckst. Ausserdem ist die Frage, warum du nur für q prüfst, ob es lang genug ist, für p jedoch nicht.
Die Prüfung counter == nist am Methodenende auch nicht gut platziert, denn selbst wenn eine passende Übereinstimmung gefunden wurde, kann sich der Wert von counter danach wieder geändert haben. Ausserdem fällt auf, dass du counter nie zurück setzt.
 

javaerd

Mitglied
So könnte deine Lösung aussehen. Der Code findet die aufeinander folgenden gleichen Elemente.

Java:
static boolean c(char[] p, char[] q, int n) {
        int tmp = 0;
        for (int i = 0; i < p.length; i++) {
            for (int j = 0; j < q.length; j++) {
                if (p[i] == q[j]) {                 //falls  Elemente gleich dann
                    n++;                              //inkrementiere n und i
                    i++;                               // i muss aufgrund des folgenden continues inkrementiert werden da sonst mit der gleichen stelle verglichen wird
                    continue;                        // weil continue bewirkt das j nicht wieder 0 wird sondern an der gleichen stelle weitergemacht wird
                } else {
                    tmp = n;                     //falls ein ungleiches kommt, die gefunden in tmp zwischenspeichern
                }
            }
        }
        if (tmp > 1) {
            return true;
        } else {
            return false;
        }
    }

Ein Hacken ist jedoch, wenn 2 oder 3 aufeinander folgende Elemente gefunden werden, und dann ein ungleiches folgt, aber dann wieder gleiche folgen, kommt es so zum Problem. Dann wird n an der stelle 3 weitergezählt, falls das relevant ist sollte man dies noch modifizieren.
 

Meniskusschaden

Top Contributor
Ich glaube, dein Programm löst ein anderes Problem, als das des TE. Folgender Aufruf liefert beispielsweise true, obwohl es überhaupt keine Übereinstimmung gibt:
Java:
c("abc".toCharArray(), "def".toCharArray(), 3)
 

Flown

Administrator
Mitarbeiter
Warum werden hier ständig Lösungen gepostet? Dies ist ein Forum, das Hilfe zur Seblsthilfe leistet.
Wenn hier andauernd Code gelierfert wird, der obendrein nicht mal richtig ist, dann ist das einfach kontraproduktiv.

Da es sich um eine Klausurvorbereitung handelt, werd ich mal was dazu beitragen.
Java:
public static boolean c(char[] p, char[] q, int n) {
  if (p == null || q == null || n > Math.min(p.length, q.length)) {
    return false;
  }
  for (int i = 0; i < p.length - n; i++) {
    label: for (int j = 0; j < q.length - n; j++) {
      for (int k = 0; k < n; k++) {
        if (p[i + k] != q[j + k]) {
          continue label;
        }
      }
      return true;
    }
  }
  return false;
}
Ohne Labels:
Java:
public static boolean c(char[] p, char[] q, int n) {
  if (p == null || q == null || n > Math.min(p.length, q.length)) {
    return false;
  }
  for (int i = 0; i < p.length - n; i++) {
    for (int j = 0; j < q.length - n; j++) {
      if (isMatchingSequence(p, q, i, j, n)) {
        return true;
      }
    }
  }
  return false;
}

private static boolean isMatchingSequence(char[] p, char[] q, int i, int j, int n) {
  for (int k = 0; k < n; k++) {
    if (p[i + k] != q[j + k]) {
      return false;
    }
  }
  return true;
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
S überschneidende Char-Arrays, zu einem Längeren verbinden Java Basics - Anfänger-Themen 7
D Eine Stelle eines Char- Arrays nach dem vorkommen in einem ganzem anderem Array überprüfen Java Basics - Anfänger-Themen 20
Fab1 char Arrays vergleichen Java Basics - Anfänger-Themen 4
I char arrays zu string Java Basics - Anfänger-Themen 7
M Problem bei Arrays mit Char Java Basics - Anfänger-Themen 3
M Palindrom Test mit Char-arrays! Java Basics - Anfänger-Themen 3
B Länge eines Char-Arrays bestimmen Java Basics - Anfänger-Themen 7
M FileReader.read(char[]) - Größe des Arrays? Java Basics - Anfänger-Themen 4
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
D 2D Char Array into String Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
Tommilee Char ausgeben Java Basics - Anfänger-Themen 5
M error: '.class' expected switch(char) Java Basics - Anfänger-Themen 32
JordenJost char variable funktioniert irgendwie nicht a+b ergibt nicht à Java Basics - Anfänger-Themen 4
java-starter Erste Schritte Eingabe in Char wert umwandeln Java Basics - Anfänger-Themen 7
P9cman Char Index rekursiv finden Java Basics - Anfänger-Themen 4
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
O Ich ahbe einen char und diesen soll ich bei .matches prüfen, also ob der char in meiner Zeichenkette vorhanden ist, wie mache ich das? Java Basics - Anfänger-Themen 9
W char über die Konsole? Java Basics - Anfänger-Themen 7
C char c Java Basics - Anfänger-Themen 13
D String und char in String speichern Java Basics - Anfänger-Themen 5
A Löschen von Leerzeichen in einem char array ohne methoden Java Basics - Anfänger-Themen 6
R String in char-Array übertragen Java Basics - Anfänger-Themen 5
P Methoden Namen trennen mit .substring(), char.At(), .lenght() Java Basics - Anfänger-Themen 8
Z Char Array an zufälligen stellen mit einem "x" füllen. Java Basics - Anfänger-Themen 4
A Datentyp char Java Basics - Anfänger-Themen 27
A Char und modulo Java Basics - Anfänger-Themen 8
A char array wird überschrieben Java Basics - Anfänger-Themen 6
F Switch case wird als char nicht erkannt.... Java Basics - Anfänger-Themen 6
E 2D Array - char durch die Matrix "wandern" lassen Java Basics - Anfänger-Themen 7
I Methoden char Array Aufgabe (bitte hierbei um Hilfe) Java Basics - Anfänger-Themen 3
D Datentypen Char deklaration Java Basics - Anfänger-Themen 4
I wieder mit einer Umwandelung habe ich Problem (diesmal von char Array zu char) Java Basics - Anfänger-Themen 1
I char Array to String Java Basics - Anfänger-Themen 3
C (char) Array einlesen Java Basics - Anfänger-Themen 8
J Java char.at() Probelm Java Basics - Anfänger-Themen 12
S char auf buchstabe/zeichen prüfen Java Basics - Anfänger-Themen 1
H char-Array Java Basics - Anfänger-Themen 22
M Die länge von char Java Basics - Anfänger-Themen 6
T Methoden char wird nicht ausgegeben Java Basics - Anfänger-Themen 3
R Fehler bei ASCII Char zu Int Umwandlung Java Basics - Anfänger-Themen 2
C Methoden String in char Array Java Basics - Anfänger-Themen 3
T Datentypen char als Buchstaben statt als Zahl ausgeben Java Basics - Anfänger-Themen 4
kokojamboo92 char mehrfach ausgeben.. Java Basics - Anfänger-Themen 2
T Erste Schritte Char 'Anführungszeichen' Tastaturkürzel Java Basics - Anfänger-Themen 1
H Compiler-Fehler Out of Bunce Exception bei einem Char Java Basics - Anfänger-Themen 6
E Wie wird in Java ein Char-Array terminiert ? Java Basics - Anfänger-Themen 15
C char in String suchen und durch anderen String ersetzen Java Basics - Anfänger-Themen 2
C Compiler-Fehler from int to char Java Basics - Anfänger-Themen 2
T Object zu Char zu String Java Basics - Anfänger-Themen 6
W Char Array bearbeiten Java Basics - Anfänger-Themen 6
A Char-Array erstellen Java Basics - Anfänger-Themen 35
D Hilfe bei int wert von char Java Basics - Anfänger-Themen 7
W String auf char[] umwandeln Java Basics - Anfänger-Themen 3
Z char Array unbekanntes Zeichen selbstständig anlegen Java Basics - Anfänger-Themen 6
M Bestimmen, wie oft ein Char in einem Array vorkommt Java Basics - Anfänger-Themen 2
BuTTerBroTHDx Char Wert in int casten ? Java Basics - Anfänger-Themen 4
D Variablen Variable char vergleichen Java Basics - Anfänger-Themen 5
A Probleme beim Methodenaufruf von char[] ! Java Basics - Anfänger-Themen 10
C char array-positionstausch Java Basics - Anfänger-Themen 6
R Anzahl von Zeichen in einem Char Array Java Basics - Anfänger-Themen 4
C String-zaehleZeichen(String str,char[]c) Java Basics - Anfänger-Themen 9
L zweidimensionales char array reihenfolge ändern ? Java Basics - Anfänger-Themen 2
D Best Practice String aufbau - Char Array oder Anhängen Java Basics - Anfänger-Themen 11
S For Schleife Char Array Java Basics - Anfänger-Themen 1
V char Eingabe aber nur für Buchstaben Java Basics - Anfänger-Themen 4
K PasswordField auslesen und in char speichern Java Basics - Anfänger-Themen 2
L Frage zum Zeichensatz Char Java Basics - Anfänger-Themen 2
L Frage zum Typ Char (Zeichensatz) Java Basics - Anfänger-Themen 8
J Fehlermeldung : cannot invoke char(at) int on the primitive type int --- Anfänger Java Basics - Anfänger-Themen 5
P Char aus einem String auswählen Java Basics - Anfänger-Themen 4
W char-Array auf bestimmte Zeichen prüfen Java Basics - Anfänger-Themen 10
J Buchstabe (char) an zufällige Position eines Strings einfügen Java Basics - Anfänger-Themen 1
B char Array mit ints Java Basics - Anfänger-Themen 7
F Char in Long umwandeln? Java Basics - Anfänger-Themen 2
J Char-Array - NullPointerException Java Basics - Anfänger-Themen 3
X Compiler-Fehler Possible loss of precision bei addition von int und char Java Basics - Anfänger-Themen 5
J char-Array rückwärts ausgeben und in neues Char-Array speichern Java Basics - Anfänger-Themen 3
D Methode die statt char[] ein "null" zurück gibt Java Basics - Anfänger-Themen 8
P Methoden suche funktion die char wert ausgibt wenn man numerischen wert und radix angibt Java Basics - Anfänger-Themen 1
R Char wird in System.out.print(); nicht ausgegeben Java Basics - Anfänger-Themen 6
J Char-Rechnen Java Basics - Anfänger-Themen 8
E Input/Output convert string to two dimensional char and output = matrix Java Basics - Anfänger-Themen 2
S Array - index von Benutzer eingegebenen char ausgeben Java Basics - Anfänger-Themen 3
M char Array füllen Java Basics - Anfänger-Themen 2
H ArrayList mit char- Array befüllen Java Basics - Anfänger-Themen 12
M Warum ist char a + char b 196 Java Basics - Anfänger-Themen 4
J Datentypen Cast von int zu char führ zu 'Sonderzeichen' Java Basics - Anfänger-Themen 2
M Erste Schritte konvertierung von int zu char Java Basics - Anfänger-Themen 3
B Char-Vergleich Sonderzeichen Java Basics - Anfänger-Themen 6
A Char Bytes Umwandlung und Darstellung Java Basics - Anfänger-Themen 3
R Input/Output einzelnes char aus .txt lesen Java Basics - Anfänger-Themen 11
P Datentypen String auf JTextField wird zu Char-Array und anschließend zu int Java Basics - Anfänger-Themen 12
M String in char-weise vergleichen und ausgeben Java Basics - Anfänger-Themen 5
V while verlassen, char Java Basics - Anfänger-Themen 2
S Datentypen Ein String in ein Char und ein Double wandeln Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben