c语言中缀表达式求值_逆波兰表达式

(一)逆波兰表达式介绍:

表达式一般由操作数(Operand)、运算符(Operator)组成,例如算术表达式中,通常把运算符放在两个操作数的中间,这称为中缀表达式(Infix Expression),如A+B。

波兰数学家Jan Lukasiewicz提出了另一种数学表示法,它有两种表示形式:

把运算符写在操作数之前,称为波兰表达式(Polish Expression)或前缀表达式(Prefix Expression),如+AB;把运算符写在操作数之后,称为逆波兰表达式(Reverse Polish Expression)或后缀表达式(Suffix Expression),如AB+;前后缀表达式的出现是为了方便计算机处理,它的运算符是按照一定的顺序出现,所以求值过程中并不需要使用括号来指定运算顺序,也不需要考虑运算符号(比如加减乘除)的优先级。

先介绍中简单的人工转化方法:

假设有一个中缀表达式a+b*c-(d+e):

  1. 首先将这个中缀表达式的所有运算加括号((a+(b*c))-(d+e))
  2. 然后将所有运算符放到括号后面,这样就变成了((a(bc)* )+ (de)+ )-
  3. 把所有括号去掉abc*+de+-,最后得出的结果就是后缀表达式。

(二)算法

一、 将中缀表达式转换成后缀表达式算法:

从左到右遍历中缀表达式的每一个数字和符号,若是数字就输出即成为后缀表达式的一部分;若是符号,则判断其与栈顶符号的优先级(没有括号,乘除优先于加减),是右括号或优先级低于栈顶符号,则栈顶元素依次出栈并输出,并将当前符号进栈,一直到最后输出后缀表达式为止。

单把优先级低于栈顶符号,则栈顶元素依次出栈并输出这句话截取出来如何思考?这样做的结果优先级高的将更靠近操作数,在后缀表达式进行求值的时候,就会被先计算;其实后缀表达式已经把优先级蕴含在顺序中了。

二、逆波兰表达式求值算法:

1、循环扫描语法单元的项目。

2、如果扫描的项目是操作数,则将其压入操作数堆栈,并扫描下一个项目。

3、如果扫描的项目是一个二元运算符,则对栈的顶上两个操作数执行该运算。

4、如果扫描的项目是一个一元运算符,则对栈的最顶上操作数执行该运算。

5、将运算结果重新压入堆栈。

6、重复步骤2-5,堆栈中即为结果值。

二、将中缀表达式转换成前缀表达式算法:

从右到左遍历中缀表达式的每一个数字和符号,若是数字就输出即成为后缀表达式的一部分;若是符号,则判断其与栈顶符号的优先级(没有括号,乘除优先于加减),是左括号或优先级高于栈顶符号,则栈顶元素依次出栈并输出,并将当前符号进栈,一直到最后输出前缀表达式为止。

二、波兰表达式求值算法:

  1、从右到左依次扫描语法单元的项目。

  2、如果扫描的项目是操作数,则将其压入操作数堆栈,并扫描下一个项目。

  3、如果扫描的项目是一个二元运算符,则对栈的顶上两个操作数执行该运算。

  4、如果扫描的项目是一个一元运算符,则对栈的最顶上操作数执行该运算。

  5、将运算结果重新压入堆栈。

  6、重复步骤2-5,堆栈中即为结果值。

8774f3d5a3d0ba00f983dce9dc07a398.png

(三)代码实现:

package 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值