利用堆栈进行四则运算

本文介绍了如何利用堆栈将中缀表达式转换为后缀表达式,并详细阐述了转换规则。通过将中缀表达式如9+((10-2)*3+3*3)*4+10/2转化为后缀表达式9 10 2 - 3 * 3 3 * + 4 * + 10 2 / +,然后遵循后缀表达式的计算规则,可以方便地进行四则运算。文章最后给出了完整的C++代码实现。
摘要由CSDN通过智能技术生成

       我们正常的四则运算在计算机里是并不被识别的,因此想要利用程序实现四则运算就需要先将我们熟悉的中缀表达式转化为无需括号的后缀表达式。这个后缀表达式是由波兰的逻辑学家JAN提出,也称为逆波兰式。


       利用堆栈转换后缀表达式:

       中缀表达式:9+((10-2)*3+3*3)*4+10/2 转化为后缀表达式:9 10 2 - 3 * 3 3 * + 4 * + 10 2 / +

规则:从左到右遍历中缀表达式的每一个数字和符号,若是数字就输出,即成为后缀表达式的一部分;若是符号则先判断是否是右括号如若是右括号则输出栈顶到左括号间的所有符号成为后缀表达式一部分,如若不是则再判断其与栈顶符号的运算优先级,输出从栈顶高优先级到第一个低于当前符号优先级(或者左括号)这之间所有符号并将当前符号入栈,一直到最终输出后缀表达式为止。

       后缀表达式的计算:

规则:从左到右遍历后缀表达式的每个数字和符号,遇到数字就进栈,遇到符号就将处于栈顶两个数字出栈,进行运算(如果是减被减数是第二个数)运

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值