首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从后缀表达式创建二叉树

从后缀表达式创建二叉树
EN

Stack Overflow用户
提问于 2015-03-21 21:01:13
回答 1查看 5.5K关注 0票数 1

假设我有以下后缀表达式: 5372-*-

我想从这个表达式中创建一个二叉树。我的algoritm是:如果我的char是数字,那么将它放入一个堆栈中,如果它是一个操作符,则从堆栈中弹出两个元素,并使它们成为运算符的子类。然后将操作符推到堆栈中。这看起来很管用,但我无法将我创造的小树连接起来。

我目前的代码是:

代码语言:javascript
复制
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);
    }
}

我的考试课:

代码语言:javascript
复制
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);

    }

我的产出是:

代码语言:javascript
复制
par-
cright2
cleft7
par*
cright-
cleft3
par-
cright*
cleft5
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-21 21:40:31

使用Stack of TreeNodes,而不是chars的Stack。毕竟,您必须组合TreeNodes,而不是chars:

代码语言:javascript
复制
public void myInsert(char ch, Stack<TreeNode> s) {
    if (Character.isDigit(ch)) {
        // leaf (literal)
        s.push(new TreeNode(ch));
    } else {
        // operator node
        TreeNode tParent = new TreeNode(ch);

        // add operands
        tParent.right = s.pop();
        tParent.left = s.pop();

        // push result to operand stack
        s.push(tParent);
    }
}

TreeNode

代码语言:javascript
复制
public class TreeNode {
    public TreeNode right = null;
    public TreeNode left = null;
    public final char ch;

    TreeNode(char ch) {
        this.ch = ch;
    }

    @Override
    public String toString() {
        return (right == null && left == null) ? Character.toString(ch) : "(" + left.toString()+ ch + right.toString() + ")";
    }

}

main

代码语言:javascript
复制
public static TreeNode postfixToTree(String s) {
    Stack<TreeNode> stree = new Stack<>();

    BST b = new BST();
    for (char ch : s.toCharArray()) {
        b.myInsert(ch, stree);
    }
    return stree.pop();
}

public static void main(String[] args) {
    System.out.println(postfixToTree("5372-*-"));
    System.out.println(postfixToTree("512+4*+3−"));
    System.out.println(postfixToTree("51*24*+"));
}

这个会打印出来

代码语言:javascript
复制
(5-(3*(7-2)))
((5+((1+2)*4))−3)
((5*1)+(2*4))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29187998

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档