二叉树的应用——表达式树

简介

假设:对于一个运算表达式,只考虑2元运算(如加减乘除 )和 操作数,我们就可以用一个二叉树去存储这个表达式:用叶子结点存储操作数,内部结点存储运算符,这样的二叉树就是一个表达式树。由于运算符都是二元的,则这个树实质也是一个满二叉树。

 

遍历表达式树

先序遍历表达式树,得到的是前缀表达式(波兰表达式)

中序遍历表达式树,得到的是中缀表达式

后序遍历表达式树,得到的是后缀表达式(逆波兰表达式)

 

 

 

 构建表达式树

可以从后缀表达式来构建一个表达式树,如果是中缀表达式,则可以先转化为后缀表达式,这篇文章有介绍->Click Me

算法:

//由一个后缀表达式构造一个表达式数,返回。
createExpressionTree(suffixExpression)
    stack s  <- empty stack;
    for each element E in suffixExpression do
        if(E is 操作数 )
            Node tree = new Node(E)
            s.push(tree)
        else if(E is 运算符)
            Node secondOperand = s.pop()
            Node firstOperand  =s.pop() 
            Node tree = new Node(E)
            tree.setLeft(firstOperand)
            tree.setRight(secondOperand)
            s.push(tree);
     //理想情况下,栈最后只有一个Node,就是整个表达式的root。         
    return s.pop()      
   

 

转载于:https://www.cnblogs.com/lulipro/p/7563217.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值