后缀、中缀表达式

【数据结构】后缀、中缀表达式

中、后缀表达式的转换

后->中:

运算符号放在两个操作数的后面,叫作后缀表达式,如23+2+3
有多个运算符号运算顺序取决于运算符号的出现顺序,将后缀表达式转换成中缀表达式的方法为:从左到右遍历后缀表达式,直到遍历到第一个运算符号,取该运算符号前的两个操作数进行运算并将运算结果作为新的操作数替换掉此前的运算符号以及两个操作数,反复此操作直到最后一对操作数完成运算,如234*+5/ 表示的是 (2+3*4)/5

中->后:

从左到右依次遍历表达式,若遇到操作数,则直接输出,若遇到运算符号,则遵循如下规则进行处理:
1.若栈当前为空,则直接将运算符号进栈。
2.若栈不为空且当前运算符号的优先级比栈顶运算符号的优先级高或者当前为’('时,直接将当前运算符号进栈。
3.若栈不为空且当前运算符号比栈顶运算符号的优先级低,则将栈顶运算符号出栈输出并继续将其对比新栈顶运算符号的优先级。
4.若当前运算符号比栈顶运算符号的优先级相同,则将栈顶运算符号出栈输出,将当前运算符号入栈。
5.若当前为‘)’时,将栈中对应的‘('上面的运算符号按规则出栈 考虑到有多对括号,取最靠近‘)’的‘(’
图片来源于中国大学MOOC-浙江大学数据结构课程
图片来源于中国大学MOOC-浙江大学数据结构

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值