中缀表达式转后缀表达式

一、概念
(A*B + C ) - B   ==> AB*C+B- 
二、分析(不考虑符号在前)
使用栈来解决问题,为什么?
栈中存储运算符和(和)
前提1 : 对于没有括号的表达式,运算遵循先乘除后加减并且乘除之间无优先级,加减之间无优先级
          情况1: A + B - C  ===》+ 在 - 之前 对应  1.+入栈   2.+ 出栈  - 出栈
          情况2: A *  B - C  ===》 * 在 - 之前 对应  1. *入栈   2. * 出栈  - 入栈
          情况3: A -  B * C  ===》 * 在 - 之前 对应  1. -入栈   2. * 入栈
          情况4: A * B * C   ===》 * 在 - 之前 对应  1. *入栈   2. * 出栈  * 入栈
前提2:面对(和),将(和)之间的表达式看做一个简单的表达式,即内部符合前提1
          情况1:(作为一个字表达式的开始必须入栈相当于是开始符号#,见注1  
          情况2: 表达式内部遵循前提1,同时遇到 表达式结束,即 出现作为最高优先的符号与其匹配的 (之间的所有的子运算,必然                                
                    符合前提1,并且是 独立的,因此 的出现相当于前提1 中的运算结束,因此需要将 和其后的运算符出栈 

前提3:(和)之间可能存在嵌套情况,任何不嵌套的括号组合都是看做独立的符合前提1,因此嵌套的括号组合依然在整体上符合前提1

三、实现:根据以上分析,可以得出以下的优先级表

符号
(
*/
+-
)
栈内
1
3
6 不可能在站内
栈外
6 保证一定入栈即是前提2.情况1
4   4优先级高于5保证前提1.情况4
     4优先级低于3保证前提1.情况3
     
2  2优先级高于3保证前提1.情况1
    2优先级高于4保证前提1.情况2
1  保证(和)之间所有的符号都出栈即是前提2.情况3

操作:优先级相同(和)栈内符号出栈,栈外符号 不入栈
操作:栈内优先级高,栈外符号入栈,栈内符号不出栈
操作:栈外优先级高,栈内符号出栈,栈外符号入栈
操作:遇到终止符截止出栈==》栈空算法结束,在中缀表达式前后加#,并且优先级都是0
【注1】#作为一个表达式子的开头和结尾相当于一个最大的括号

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值