zoukankan      html  css  js  c++  java
  • 四则运算表达式分解,前中后缀表达式(栈的应用)

    前/中/后缀表达式的转换(首先需要明白三者之间的转换)   

       自然表达式转换为前/中/后缀表达式,其实是很简单的。首先将自然表达式按照优先级顺序,构造出与表达式相对应的二叉树,然后对二叉树进行前/中/后缀遍历,即得到前/中/后缀表达式
     
        举例说明将自然表达式转换成二叉树:
     
        a×(b+c)-d
     
        ① 根据表达式的优先级顺序,首先计算(b+c),形成二叉树
       tree1.JPG
       
       ②然后是a×(b+c),在写时注意左右的位置关系
       tree2.JPG
     
       ③最后在右边加上-d
       tree3.JPG
     
     
      然后最这个构造好的二叉树进行遍历,三种遍历的顺序分别是这样的:
     
       ① 前序遍历:根-左-右
       ② 中序遍历:左-根-右
       ③ 后序遍历:左-右-根
     
        所以还是以刚才的这个例子,在最终二叉树的基础上可以得出:
     
        前缀表达式:-*a+bcd
        中缀表达式:a*b+c-d
        后缀表达式:abc+*d-
  • 相关阅读:
    [转载]四大Java EE容器
    [转载]javaEE规范和SSH三大框架到底有什么关系
    javaee包含的服务和组件
    Java类文件最大限制
    oracle给字段添加描述
    apache commons工具包
    redis教程
    git学习
    编程人物
    程序员必须了解的5大编程准则
  • 原文地址:https://www.cnblogs.com/Ph-one/p/10060746.html
Copyright © 2011-2022 走看看