Klammerung bei Strings

ocsme

Top Contributor
Guten Tag,

ich komme hier nicht wirklich weiter :(
Möchte mir eine Methode schreiben die Überprüft ob ein String richtig geklammert ist.
Also z. B. ist dieser String richtig geklammert: 3+(4-5[as])%()[[(bfg)]] falsch wäre sowas: ([dfdf)a] da die Runde klammer später zu gehen muss. Hier ist mal mein Anfang. Bis jetzt habe ich nur überprüft ob die summe der Klammern stimmen sprich wenn eine Runde, Eckige oder Geschweifte Klammer auf geht muss auch wieder eine zu gehen wenn mehr zu gehen ist es Falsch.
Doch wie mache ich das nun wenn sich eine Klammer vordrängeln würde. Hat da jemand einen Tipp?

Java:
        String s="[as(dd])f)adf()";
        char[] c=s.toCharArray();
        int rcounter=0;
        int ecounter=0;
        int gcounter=0;
        for(int i=0;i<c.length;i++) {
            if(c[i]=='(')
                rcounter++;
            else if(c[i]=='[')
                ecounter++;
            else if(c[i]=='{')
                gcounter++;
            else if(c[i]=='}') {
                gcounter--;
                if(gcounter<0)
                    System.out.println("Fehler");
            }
            else if(c[i]==']') {
                ecounter--;
                if(ecounter<0)
                    System.out.println("Fehler");
            }
            else if(c[i]==')') {
                rcounter--;
                if(rcounter<0)
                    System.out.println("Fehler");
            }
       
        }

Danke im voruas :)

lG
 
X

Xyz1

Gast
Das geht mit einem sg Rangierbahnhof, aber der String s iss nicht vollständig geklammert. :(
 

Robat

Top Contributor
Hier mal als Pseudocode:
Code:
- Stack für die Character deklarieren
- für jedes Zeichen currentChar im String 
   - wenn currentChar gleich '(', '{' oder '[' ist
      - currentChar auf den Stack pushen
   - wenn currentChar gleich ')', '{' oder ']' ist
      - pop Zeichen von Stack und speicher es in a
      - wenn a nicht das öffnende Pendant zu currentChar ist
          - Fehler gefunden
 

ocsme

Top Contributor
Ich weiß leider derzeit nicht zu 100% ob es richtig läuft. Hab es aber mit hilfe von Prioritäten gemacht! Denke das ist so etwas in der Art was du meintest Wissender!
Denn mit deiner Aussage an sich konnte ich nicht so viel Anfangen :(

Java:
        String s="{as(}dd])f)adf()";
        char[] c=s.toCharArray();
        int ranger=1;
        int rangee=2;
        int rangeg=3;
        int prio=0;
        int rcounter=0;
        int ecounter=0;
        int gcounter=0;
        for(int i=0;i<c.length;i++) {
            if(c[i]=='(') {
                rcounter++;
                prio=ranger;
            }
            else if(c[i]=='[') {
                ecounter++;
                prio=rangee;
            }
            else if(c[i]=='{') {
                gcounter++;
                prio=rangeg;
            }
            else if(c[i]=='}') {
                gcounter--;
                if(prio!=rangeg)
                    System.out.println("Falsche Reihenfolge");
                if(gcounter<0)
                    System.out.println("Fehler");
            }
            else if(c[i]==']') {
                ecounter--;
                if(prio!=rangee)
                    System.out.println("Falsche Reihenfolge");
                if(ecounter<0)
                    System.out.println("Fehler");
            }
            else if(c[i]==')') {
                rcounter--;
                if(prio!=ranger)
                    System.out.println("Falsche Reihenfolge");
                if(rcounter<0)
                    System.out.println("Fehler");
            }
       
        }
 

Robat

Top Contributor
Hier mal als Beispiel .. ich persönlich würde es trotzdem mit einem Stack und ggf. einer Map machen. Damit könnte man ein paar Abfragen noch verkürzen / sich ganz sparen
Java:
public class ParantheseChecker{
 
  public static boolean hasBalancedParantheses(String expression) {
    char[] stack = new char[expression.length()];
    int stackPointer = 0;
    boolean error = false;
  
    for(char currentChar : expression.toCharArray()) {
      if(isOpeningBrace(currentChar)) {
        stack[stackPointer++] = currentChar;
      } else if(isClosingBrace(currentChar) && stackPointer > 0) {
          char c = stack[--stackPointer];
          if(noMatchingBraces(currentChar, c)) {
             return false;
          }
       }
    }
    return true;
  }
 
  private static boolean isOpeningBrace(char c) {
    return c == '(' || c == '{' || c == '[';
  }
 
  private static boolean isClosingBrace(char c) {
    return c == ')' || c == '}' || c == ']';
  }
 
  private static boolean noMatchingBraces(char closingBrace, char openingBrace) {
    switch(closingBrace) {
      case ')': return openingBrace != '(';
      case ']': return openingBrace != '[';
      case '}': return openingBrace != '{';
      default: return false;
    }
  }


  public static void main(String[] args) {
    String expression = "([])3+(4-5[as])%()[[((bfg))]]";
    if(!hasBalancedParantheses(expression)) {
        System.out.println("Fehler");
    } else {
        System.out.println("Korrekt");
    } 
  }
}
 

ocsme

Top Contributor
Ja stimmt ich werde es später mit einem array versuchen und so eine Art von Stack mal schauen ob ich es hin bekomme.
Mit der Prio sollte es ja auch klappen wie ich es oben gemacht habe.
Meniskusschaden danke für die Antwort Rekursive Funktionen sind nicht so mein Fall da ich sie nicht wirklich hin bekomme :( muss noch viel üben :p

Robat Danke für die super Antwort zur Not werde ich das nehmen bzw. es so ähnlich dann machen :) denn einen Stack bzw. Datenstrukturen zu Implementieren wollte ich eh noch =)

LG
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J implizite Klammerung Java Basics - Anfänger-Themen 70
C Do-While Schleife (Fehler bei der Klammerung?) Java Basics - Anfänger-Themen 8
C Klammerung testen Java Basics - Anfänger-Themen 10
B Klammerung testen Java Basics - Anfänger-Themen 12
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
G Strings auf Gleichheit prüfen - Aufgabe vom Prof. Java Basics - Anfänger-Themen 5
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
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

Ähnliche Java Themen

Neue Themen


Oben