利用堆栈进行表达式求值的方法(一)

例如给定如下的算术表达式:(1+((2+3)*(4*5)),需要解决的问题是如何通过代码程序进行解析并求值,本文的主要目的是利用其中的方法去解决正则表达式解析、sql语法解析等涉及到编译原理方面的某些问题,当然编译原理方面的知识远比这复杂,我们的重点是语法解析这个主题。

本文也是对“算法(第四版)”中的1.3.1.7章节的总结和完善,实际上如果直接采用文中的方法是解决不了该例题“(1+((2*3+4)*(4*5))”的,不过它提供了解决的思路,注意:简单起见括号、数值、操作符均以空格分开便于程序解析,先描述原始步骤:

1、准备两个堆栈,一个用于存储数值,另一个用于存储操作符;

2、从左向右扫描表达式遇到左括号忽略掉,遇到数值将其压入数值栈,遇到操作符将其压入操作符栈;

3、遇到右括号后从操作符栈中先弹出一个操作符,然后从数值栈从弹出两个操作数进行计算,得出值再压入数值栈中;

4、按照1~3的步骤,当表达式扫描完毕后计算出的结果就是最终值。

该算法确实解决了第一个例题,但是第二个就会出错,因为第3步在计算2*3+4时就有问题,解决的方法放在下篇讨论。

转载于:https://my.oschina.net/u/1268334/blog/3023463

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值