Probleme mit stack

Hi Leute, es ist spät, ich bin wieder mal kurz vorm ausflippen, bzw. hab ich schon wieder einige Sachschäden an meinen Inventar zu verzeichnen. Wenn mir jemand sagen könnte, warum meine besch....ne Schleife beim ersten pushen auf den Stack einfach nicht pusht, dann würde er mein Herz schonen!

Wir sollen einen Klammerausdruck auf "wohlgeformtheit" überprüfen.Ich pushe also solange geöffnete Klammern auf den Stack, bis eine schließende kommt. Dann nehme ich die oberste geöffnete vom stack. So verfahre ich den gesamten Klammerausdruck entlang. Wenn der Stack am Ende leer ist, habe ich eine wgf Klammerausdruck, ansonsten eben nicht. Habe soweit auch eine Kontrollausgabe eingebaut.

Bitte nicht gleich wieder draufkloppen, meine Laune ist eh im Keller!

Danke im Voraus

ansonsten

juts nächtle!


Hier die ausführbare Klasse, die die angesprochene if-Schleife zur Abarbeitung des Klammerausdrucks enthält:

Java:
import java.util.*;
 public class Applikation{

	public static boolean wgk(String klammerAusdruck, IStack stack ) throws IllegalArgumentException{
		Scanner in = new Scanner(System.in);
		for(int i=0;i<klammerAusdruck.length(); i++){								//for-Schleife durchläuft übergebenen Klammerausdruck
			//if(klammerAusdruck.charAt(i)!= '('){									//Falls keine öffnende Klammer
			//	if(klammerAusdruck.charAt(i)!= ')');								//und keine schließende Klammer
			//		throw new IllegalArgumentException("Kein Klammerausdruck");		//wird Exception geworfen
			//}//if
		if(klammerAusdruck.charAt(i)== '(')											//Wenn eine öffnende Klammer, auf den Stack pushen
		stack.push(klammerAusdruck.charAt(i));

		if(klammerAusdruck.charAt(i)== ')')											//Wenn eine schließende Klammer, vom stack popen
		stack.pop();
		
		String ausgabe = stack.toString();
		System.out.println(ausgabe);
		}//for
		
		if(stack.toString()=="leer")return true;
		else return false;
	}//wgk

	
	
  	public static void printBinary(int zahl, IStack stack ) throws IllegalArgumentException{
   
	}// printBinary
    
    /*
            * In der main-Methode muss die Exceptionbehandlung durchgeführt werden
	    		
          */			
   	public static void main(String[] argv){
	
	
    	    IStack stack = new CharListe();
       		String s1 = "((())())";
			String s2 = "(()())())";
			
			printBinary(11, stack);
			printBinary(185, stack);
			try{
				if(wgk(s1,stack)) System.out.println("Wohlgeformter Klammerausdruck!");
				else System.out.println("Kein wohlgeformter Klammerausdruck!");
				if(wgk(s2, stack))System.out.println("Wohlgeformter Klammerausdruck!");
				else System.out.println("Kein wohlgeformter Klammerausdruck!");
			}
			catch(IllegalArgumentException e){
				System.out.println(e.getMessage());
			}
		  	
   }//main
} //Applikation

Hier die Klasse mit den Methoden, die das Interface implementiert:
Java:
import java.util.*;


public class CharListe implements IStack {

	/** 
	   * Klasse beschreibt den Datentyp eines Stack-Elementes mit dem
	   * Informationsteil  data und dem Organisationsteil next (Verweis zum nächsten Stackelement)
	  */
	class Element {
	   char data;
	   Element next;
    }
   
	
	private int size;       // aktuelle Anzahl der StackObjekte
	private Element topp;	// oberstes Stack-Element des Stacks
	
	public CharListe() { // Konstruktor initialisiert Attribute topp und size
		System.out.println("ADT IStack, Listenimplementierung");
		//Anweisungen
	}

	/**Methode entfernt alle Elemente aus dem Stack
	   *@param -
	   *@return - void
	*/
	public void clear() {
		if(topp==null) return;
		topp = null;
		return;
	
	//Anweisungen
	
	}

	
	/**Methode prüft, ob Stack Elemente enthält
	   *@param -
	   *@return - Wahrheitswert true, falls Stack leer, sonst false
	   */
    public boolean isEmpty() {
		if(topp==null) return true;
		return false;	  
	}
	
	
	/**Methode legt ein neues Element auf den Stack
	   *@param  e - Informationsteil des neuen Elementes
	   *@return  -void
	   */
    public void push(char e){
		Element h = new Element();
		h.data = e;
		h.next = topp;
		topp = h;
		size += 1;
		
	
	} // push 
	
	
	/**Methode gibt das zuletzt auf den Stack gelegte Objekt zurück, ohne es zu entfernen
	   *@param -
	   *@return Objekt vom Typ Element
	   */
	public char top() {
		if(isEmpty()) return ' ';
		return topp.data;
	  
	}//top

	
 /**Methode entfernt das " oberste" Objekt von dem Stack
     *@param -
     *@return void
     */
   public void pop()  {
		if(isEmpty()) return;
		topp = topp.next;
		size -= 1;
		
   
   //Anweisungen
    
  }//pop

  
 /**
     * Methode liest Infokomponente der Stackelemente aus
     * und schreibt sie in eine Zeichenkette
     *@param -
     *@return Zeichenkette vom Typ String
     */ 
 public String toString() {
	String ausgabe = "";
	Element h;
	h = topp;
	if(isEmpty()) return "leer";
	while(h.next!=null){
		ausgabe+= h.data;
		h = h.next;
	}
	return ausgabe;
   
} // toString 	

}//CharList
 
Zuletzt bearbeitet:
G

Gast2

Gast
Du fügst schon richtig ein, du gibst es nur falsch aus. Das letzt Element verschluckst du einfach.
 

HoaX

Top Contributor
Strings vergleicht man mit equals nicht mit == bzw. wäre es sehr viel sinnvoller isEmpty abzufragen!
Und die Methode isEmpty könnte man auf "return (topp==null);" reduzieren.
 
G

Gast2

Gast
chars sind keine Strings sondern primitives, die musst du mit == vergleichen. HoaX bezieht sich auf den "leer" Vergleich.

Java:
    while(h.next!=null){
        ausgabe+= h.data;
        h = h.next;
    }
=>
Java:
    while(h!=null){
        ausgabe+= h.data;
        h = h.next;
    }
 
gibts ja gar nicht. An der Stelle habe ich natürlich nicht gesucht, das war die einzig vorgegebene Methode...! Das davor war natürlich Quatsch. Wollte gerade anmerken, dass das doch ein Char ist und kein String.
 
Noch eine Frage zu meiner exception in Zeile 11: Die if Bedingung darf laut compiler im Bezug auf Char keinen oder(||), noch einen logischen und(&&) Operator enthalten. Mit meinen verschachtelten if's krieg ich aber auch nix gescheites hin. Habt ihr vielleicht nen anderen Tip? Eig dürfte er sie ja in keinem der beiden Beispiele werfen, tut es aber trotzdem.



ok habs.
 
Zuletzt bearbeitet:

AquaBall

Top Contributor
Aber hier vergleichst du mit '==':
[JAVA=21] if(stack.toString()=="leer")return true;
else return false;
[/code]
Außerdem "fühlst" du die Bedeutung von if und boolean noch nciht richtig:
[JAVA=21] return stack.toString().equals("leer");
[/code]
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Probleme bei einen Stack der über drei Dateien funktionieren soll Java Basics - Anfänger-Themen 5
N Stack-Probleme Java Basics - Anfänger-Themen 2
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12
F Probleme mit privaten Klassen (abstrakten Klassen) Java Basics - Anfänger-Themen 1
H Probleme mit Klassen...oder: Eine Uhr Java Basics - Anfänger-Themen 9
G Probleme mit Konsole Java Basics - Anfänger-Themen 4
S Probleme mit GamGrid Spiel-Erstellung => Actor reagiert nicht auf Tastatur Java Basics - Anfänger-Themen 2
G Probleme mit Eclipse oder der URL Klasse Java Basics - Anfänger-Themen 5
W Verständnis Probleme bei der while-Schleife und continue Java Basics - Anfänger-Themen 21
M Probleme mit Anzeigen von String in GUI und if-Anweisung Java Basics - Anfänger-Themen 9
T Konstruktor Probleme Java Basics - Anfänger-Themen 3
W Methoden Probleme mit der Scanner Methode Java Basics - Anfänger-Themen 2
F Ja Nein Abfrage und andere Probleme Java Basics - Anfänger-Themen 5
L If Anweisung mit ArrayList Probleme Java Basics - Anfänger-Themen 6
littles_de Simbad Simulator probleme mit Sensordaten... Java Basics - Anfänger-Themen 0

Ähnliche Java Themen

Neue Themen


Oben