zoukankan      html  css  js  c++  java
  • 二叉树的应用——表达式树

    简介

    假设:对于一个运算表达式,只考虑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()      
       
  • 相关阅读:
    Git在eclipse中的使用
    Git协同开发产生的版本冲突
    git&github-远程库的拉取
    【题解】p6160 [Cnoi2020]向量
    【题解】p2388 阶乘之乘
    友情链接
    O(1)求解自然数异或和
    【题解】uva1104 chips challenge
    【题解】p1809 过河问题
    多步操作产生错误,请检查每一步的状态
  • 原文地址:https://www.cnblogs.com/lulipro/p/7563217.html
Copyright © 2011-2022 走看看