Допустим, у меня есть следующее постфиксное выражение: 5372-*-
Я хочу создать двоичное дерево из этого выражения. Мой алгоритм таков: если мой символ - число, поместите его в стек, если это оператор, вытащите два элемента из стека и сделайте их дочерними элементами оператора. Затем поместите оператор в стек. Кажется, что это работает, но мне не удается соединить маленькие деревья, которые я создаю.
Мой текущий код:
public void myInsert(char ch, Stack s) {
if (Character.isDigit(ch)) // initial cond.
s.push(ch);
else {
TreeNode tParent = new TreeNode(ch);
TreeNode t = new TreeNode(s.pop());
TreeNode t2 = new TreeNode(s.pop());
tParent.right = t;
tParent.left = t2;
s.push(ch);
System.out.println("par" + tParent.ch);
System.out.println("cright" + tParent.right.ch);
System.out.println("cleft" + tParent.left.ch);
}
}
Мой тестовый класс:
Stack stree = new Stack();
BST b = new BST();
String str = "5-3*(7-2)";
String postfix = b.convertToPosFix(str);
System.out.println(postfix);
for (char ch : postfix.toCharArray()) {
b.myInsert(ch, stree);
}
Мой вывод:
par-
cright2
cleft7
par*
cright-
cleft3
par-
cright*
cleft5