String in binären Baum umwandeln

Status
Nicht offen für weitere Antworten.
J

jhjp

Gast
Hallo Leute,
ich bin grad am Verzweifeln! Sitz jetzt glaub ich schon über 10 Stunden an diesem blöden Baum....

Folgende Aufgabe: Ein String der z.b. so aussieht: String s = "((3+4)x(1/2))" soll nun in einen Baum umgewandelt werden, der so aussieht:
x
+ /
3 4 1 2


Mein Problem: er setzt mir die Operanden immer an die falsche Stelle. Und die rechte Seite des Baumes sieht nur bei einfachen Strings korrekt aus zb.(3+2).

Ich bitte um Hilfe... weiß einfach nicht mehr weiter...

und mein Prof meint auch noch, das sei alles gar nicht so schwer *könntihnwürgen*

gruß
beni

Hier mein Code:
Code:
	public BinTree makeBinTree(String s){
		if(s.substring(0,1).matches("[0123456789]")){ //Bei Zahl			
			int i = 0; while(!s.substring(i,i+1).matches("[+-/x]") && !s.substring(i,i+1).equals(")")) i++;
			return bin( s.substring(0,i) );
		}
		if(s.indexOf("(") == 0){
			s = s.substring(1);
			return bin( makeBinTree(s.substring(0)), operant(s) , makeBinTree(rechteSeite(s)) );
		}
		return bin("");
	}
	public String operant(String s){
		int i = 0;
		if(s.indexOf("+") != -1 && s.indexOf("+") < s.indexOf(")")) i = s.indexOf("+");
		if(s.indexOf("-") != -1 && s.indexOf("-") < s.indexOf(")")) i = s.indexOf("-");
		if(s.indexOf("x") != -1 && s.indexOf("x") < s.indexOf(")")) i = s.indexOf("x");
		if(s.indexOf("/") != -1 && s.indexOf("/") < s.indexOf(")")) i = s.indexOf("/");
		return s.substring( i , i+1 );
	}
	public String rechteSeite(String s){
		int i = 0;
		if(s.indexOf("+") != -1 && s.indexOf("+") < s.indexOf(")")) i = s.indexOf("+");
		if(s.indexOf("-") != -1 && s.indexOf("-") < s.indexOf(")")) i = s.indexOf("-");
		if(s.indexOf("x") != -1 && s.indexOf("x") < s.indexOf(")")) i = s.indexOf("x");
		if(s.indexOf("/") != -1 && s.indexOf("/") < s.indexOf(")")) i = s.indexOf("/");
		return s.substring(i+1);
	}
Vollständigkeitshalber: Meine Baumklasse:
makeBinTree und operant, rechteSeite stehen in der class BinTree!
Code:
public class BinTree {
	public Node root;
	
	public BinTree(){
		root = new Node(null);
	}
	public BinTree bin(BinTree a, String t, BinTree b){
		BinTree neu = new BinTree();
		neu.root.left = a.root;
		neu.root.right = b.root;
		neu.root.value = t;
		return neu;
	}
	public BinTree bin(String t){
		BinTree neu = new BinTree();
		neu.root.value = t;
		return neu;
	}
	public static BinTree left(BinTree a){
		BinTree neu = new BinTree();
		neu.root = a.root.left;
		return neu;
	}
	public BinTree right(BinTree a){
		BinTree neu = new BinTree();
		neu.root = a.root.right;
		return neu;
	}
	public String value(BinTree a){
		return a.root.value;
	}
	public boolean isEmpty(BinTree a){
		if(a.root.value.equals("")) return true;
		else return false;
	}
}
Die Node klasse:
Code:
public class Node {
	String value;
	Node left;
	Node right;
	
	public Node(String wert){
		value = wert;
		left = null;
		right = null;
	}
}
So soll dann das Hauptprogramm aussehen:
Code:
class test extends BinTree {
	public static void main(String[] args){
		String s = "((3+4)x(1/2))";
		BinTree a = new BinTree();
		a = a.makeBinTree(s);
	}	
}
 

ronny

Bekanntes Mitglied
Hallo!

das ganze klingt ja ziemlich nach ner compiler vorlesung......

ich bin mir da aber nich so ganz sicher, ob du mit diesem string auschneid-aktionen auf dem richtigen weg bist....

FALLS das für compiler ist, dann bin ich mir aber sicher das ihr bestimmt erst ne sprachanalyse machen müsst um z. b. die rechenregeln abdecken zu können (punkt vor strich, klammern, etc).

Erst wenn du die sprache richtig analysiert und die grammatik dazu aufgestellt hast könntest du theoretisch nen recursive decent parser bauen der deinen string durchgeht.... da passiert nämlich nix anderes, als das ein "abstrakter" baum erstellt wird... ich denk mal ihr sollt halt dann in den "zwischenstationen" einfach das aktuelle zeichen in nen stringbuffer schreiben....

bin ich da auf dem richtigen weg???? weil dann könnt ich dir sprachkonstrukte geben für die grammatik für nen taschenrechner ;)
 
J

jhjp

Gast
Danke für die Antwort!
Also rechenregeln muss der Programm nicht können! Die klammern werden immer richtig gesetzt!
So ein String: 5+4*3 ist zb. als eingabe nicht erlaubt!
Einfach die Klammern aufdröseln in : Operator = Wurzel, Zahl links vom Operator = linkes Kind, Zahl rechts vom Operator = rechtes Kind. mehr net!

Hab mir auch schon überlegt, das ganze mithilfe eines Stacks zu machen. Habs auch schon programmiert, hat aber natürlich net funktioniert, bin halt n anfänger...

Aber vom Prinzip her, kann ich doch das Problem gar nicht anders lösen, als jedes Zeichen aus dem String rauszuschnippeln und ihm dann sagen, was er machen soll in Abhängigkeit von der Art des Zeichens ( ob Klammer, Zahl oder Operand)... oder?

Gruß
beni
 

ronny

Bekanntes Mitglied
hmmmmmm, ok... scheint doch ne etwas andere geschichte zu sein, wie ich dachte.....

ich kann dir nicht wirklich im moment da weiterhelfen, da müsst ich mich erstmal reindenken und selbst ausprobieren....

doch selbst ohne rechenregeln bin ich mir ziemlich sicher, dass da ne rekursion dahinter steckt, die den baum aufbaut.... denn wenn ich mir den string anschaue, dann müsstest du ja eigentlich "die Mitte" finden (der Operator mit der höchsten prio) und von da ab links rechts abwärts den baum aufbauen...... und da wären wir schon wieder bei der geschichte: "wo geht die klammer auf, wo geht sie zu..." siehe: (((3+4)x(3+4))x(3+4))

hier wäre ja nach deiner angabe quasi das 2. x das oberste im baum....

ich hasse solche aufgaben..... ;)

vielleicht hat ja doch noch jemand ne idee???
die lösung würde mich auch interessieren!!!
 

nagash56

Aktives Mitglied
Vorschlag:

Der funktioniert aber nur wenn du in deinen Baumknoten zusätzlich einen Zeiger für den Vaterknoten definierst.

Du scannst den String in einer Schleife Zeichen für Zeichen und startest mit einem leeren Baum (root = null) und führst einen pointer auf den aktuellen Knoten.

Bei "(" erzeugst du einen Knoten und hängst in links and den pointer-Knoten wenn links = null sonst rechts. pointer zeigt dann auf den neuen Knoten. Wichtig diese Knoten haben noch keinen value.

Bei Zahlen erzeugst du einen Knoten und hängst in links an den Baum wenn links = null, sonst rechts. pointer zeigt
nicht auf den neuen Knoten sondern bleibt auf dem aktuellen.

Bei Operatoren setzt du den Value des Knotens auf den pointer zeigt entsprechend dem Operator. Sonst nichts.

Bei ")" setzt du pointer auf den Vaterknoten von pointer, also pointer = pointer.getFather();

Und das machst du so lange bis der String zu Ende ist.

Also bei diesem Beispiel würde das wie folgt aussehen.
(((3+4)x(3+4))x(3+4))

Zuerst werden drei leere Knoten erzeugt jeweils links aneinander gehängt. pointer zeigt auf den niedrigsten
3 wird links von pointer gehängt, + wird in den leeren pointer Knoten eingetragen und 4 wird rechts von pointer gehängt, weil ja links schon belegt ist.
Dann kommt ")" und es wird pointer = pointer.getFather() ausgeführt und der zeiger wandert eine Ebene nach oben. Der Operator "x" wird in diesen Knoten eingetragen. Die nächste "(" erzeugt wieder einen leeren Knoten, der allerdings rechts angehängt wird weil ja links schon belegt ist, usw...
 

Wildcard

Top Contributor
Warum denn so kompliziert?

Code:
        if (s.substring(1).contains("("))
        {
            s=s.substring(1);
            Pattern pat = Pattern.compile("[\\(\\)]");
            Matcher mat = pat.matcher(s);
            Stack stack = new Stack();
            do
            {
                mat.find();
                if (mat.group(0).equals("("))
                    stack.push(mat.group(0));
                else
                    stack.pop();        
            }while(!stack.isEmpty());
            int position = mat.end();
            makeBinTree(s.substring(0,position));
            makeBinTree(s.substring(position+1,s.length()-1));
        }
        else
        {
            //rekursionsende => klammerloser Term der Form 3+4 || 6x7 || ...
        }
Die Ergebnisse in den Baum einfügen und fertig :wink:
 
G

Guest

Gast
ES GEHT!!!!!!
Vielen Dank! für Eure Hilfe:
@wildcard, tut mir leid, aber den code hab ich net verstanden, was ist denn ein pattern?
@nagash56: VIELEN DANK, hat mir am meisten geholfen!!!!!

Hier nun der Code - so ne Schleife versteh ich einfach besser als diese rekursion...:
Code:
	public BinTree makeBinTree(String s){
		BinTree a = new BinTree();
		Node zeiger, szeiger;
		zeiger = a.root;
		szeiger = null;
		
		for(;;){
			if(s.substring(0,1).equals("(")){
				if(zeiger.left == null){
					zeiger.left = new Node("");
					szeiger = zeiger;
					zeiger = zeiger.left;
				}
				else{
					zeiger.right = new Node("");
					szeiger = zeiger;
					zeiger = zeiger.right;
				}
			}
			if(s.substring(0,1).matches("[0123456789]")){
				int i = 0; while(!s.substring(i,i+1).matches("[+-/x]") && !s.substring(i,i+1).equals(")")) i++;
				if(zeiger.left == null) zeiger.left = new Node(s.substring(0,i));
				else zeiger.right = new Node(s.substring(0,i));
			}
			if(s.substring(0,1).equals("+") || s.substring(0,1).equals("-") || s.substring(0,1).equals("x") || s.substring(0,1).equals("/")){
				zeiger.value = s.substring(0,1);
			}
			if(s.substring(0,1).equals(")")){
				zeiger = szeiger;
			}
			if(s.equals(")")) break;
			
			s = s.substring(1);
		}
		return a;
	}

Nur noch ein Problem: die Wurzel des Baums ist immer null und der Termbaum hängt am linken Kind.
Aber das Problem lös ich, wenn ich Einfügen und Löschen implementiert hab....

gruß
beni
 

Wildcard

Top Contributor
gast hat gesagt.:
@wildcard, tut mir leid, aber den code hab ich net verstanden, was ist denn ein pattern?
Du benutzt doch selbst Patterns, nur noch etwas kompliziert :lol: :
Code:
s.substring(0,1).matches("[0123456789]") == s.substring(0,1).matches("(\\d)")
usw...

zum Umgang mit Patterns (ist wichtig):
http://java.sun.com/j2se/1.5.0/docs/api/java/util/regex/Pattern.html

gast hat gesagt.:
so ne Schleife versteh ich einfach besser als diese rekursion...
daran würd ich unbedingt arbeiten. Für viele Probleme eignet sich Rekursion ideal
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
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
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
Poppigescorn String mit mehreren Wörtern füllen? Java Basics - Anfänger-Themen 4
I String Expression mit Java validieren (true / false) Java Basics - Anfänger-Themen 34
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
T Maximale Anzahl von Konsonanten im String Java Basics - Anfänger-Themen 6
H String verschlüsseln - eigener Algorithmus Java Basics - Anfänger-Themen 104
N Aus einem String die Anzahl der Vokale auslesen Java Basics - Anfänger-Themen 40
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
K mit String.splitt(",") ganzen Satz erhalten? Java Basics - Anfänger-Themen 3
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7
I Validation, ob String ein Wert aus einem Enum enthält Java Basics - Anfänger-Themen 3
D String und char in String speichern Java Basics - Anfänger-Themen 5
A ObservableList<String> Java Basics - Anfänger-Themen 6
I String nach Wort suchen Java Basics - Anfänger-Themen 6
I String ersetzen, der Inhalt enthält Java Basics - Anfänger-Themen 4
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben