A+B*(C-D)-E*F的语法树如下:

计算机四则运算
1.中缀表达式
1.1定义
我们最熟悉的一种表达式A+B*(C-D)-E*F等是中缀表示法。中缀表达式是由相应的语法树中序遍历得到的。
中缀表达式先算括号里的,然后算乘除,最后算加减,但是,计算机处理中缀表达式却并不方便,因为没有一种简单的数据结构可以比较方便的从一个表达式中间抽出一部分进行计算,计算完成后再放进去,然后继续后面的计算(链表也许可以,但是,代价也是不菲)。
2.前缀表达式
2.1定义
前缀表达式又叫做波兰式。同样的道理,表达式的前缀表达式是由相应语法树的前序遍历得到的。
如上图的前缀表达式为:
- -+A * B - C D * E F
2.2求值
由前缀表达式求出结果有下面两种思路:
思路1
1.从左至右扫描表达式,如果一个操作符后面跟着两个操作数时,则计算,然后将结果作为操作数替换(这个操作符和两个操作数)
2.重复第1步,直至所有操作符处理完毕。如-+AB-CDEF,扫描到-CD时,会计算C-D=C’,表达式变成:-+ABC’EF,继续扫描到BC’,计算BC’=B’表达式变成:-+AB’*EF,继续+AB’,依此类推。
思路2
要多遍扫描表达式,并且需要将3个字符替换成1个,比较繁锁,我们可以用一个栈S2来实现计算,扫描从右往左进行。如果扫描到操作数,则压进S2,如果扫描到操作符,则从S2弹出两个操作数进行相应的操作,并将结果压进S2(S2的个数出2个进1个),当扫描结束后,S2的栈顶就是表达式结果。

本文介绍了中缀表达式、前缀表达式和后缀表达式(逆波兰式)的概念及其相互转换。中缀表达式是我们常见的运算符位于操作数之间的形式,但计算机处理不便;前缀表达式采用操作符在前,操作数在后的形式,便于计算;后缀表达式则是操作数在前,操作符在后,计算时利用栈结构。文章详细阐述了三种表达式的求值过程及转换方法,并提供了具体的示例。

6381

被折叠的 条评论
为什么被折叠?



