当前位置: 首页 > news >正文

【基础算法】表达式计算

中缀表达式:我们平常见到的正常数学式子

后缀表达式:12-3*

后缀表达式对于计算机很容易计算,只需要从头部扫描字符串。然后遇到数字就入栈,遇到运算符就取出栈顶的两个数进行运算。最后把运算结果入栈,最后栈中就会剩一个数为答案。

现给定一个中缀表达式,要求计算结果。

一般方法是,先把中缀表达式转成后缀表达式,然后计算后缀表达式的结果即可。

中缀转后缀表达式的方法:

首先建立一个专门存放运算符的栈

1.如果遇到一个数,输出该数

2.遇到左括号直接入栈

3.遇到右括号,弹出栈顶并输出,直到栈顶是左括号,然后左括号弹出(并不会输出左括号)。

4.如果遇到运算符,检查栈顶,如果栈顶的符号优先级高于等于新符号,就不断取出栈顶并输出。

最后把新符号进站。(优先级:乘除>加减>左括号)

最后依次把栈中剩余符号出栈并输出。

如果是多位数。可以扫描的时候,加些判断,把字符串转换成整数,然后计算。

如果有乘方还有&|这些逻辑运算,按照优先级规则判断即可。

http://www.lryc.cn/news/6485.html

相关文章:

  • 动态规划问题
  • 【MySQL进阶】 存储引擎 索引
  • 5 款最好的免费 SSD 数据恢复软件
  • MyBatis案例 | 使用映射配置文件实现CRUD操作——删除数据
  • CSDN 编程竞赛二十八期题解
  • DML数据操纵语言
  • 【Hello Linux】Linux工具介绍 (gcc/g++ gdb)
  • TeamFiltration:一款针对O365 AAD账号安全的测试框架
  • 你是真的“C”——Visual Studio 2022(VS2022)编译器 -—实用调试技巧
  • 数据结构与算法:7种必须会的排序以及3种非基于比较排序
  • 数据库用户数
  • nginx如何用html显示多个图片并加入播放链接
  • 【蓝桥杯集训·每日一题】Acwing 3729. 改变数组元素
  • springmvc执行流程
  • SpringMVC(2)
  • Jackson序列化json时null转成空串或空对象
  • 如何将Python的上级目录的文件导入?【from.import】
  • Java实现碧蓝航线连续作战
  • Docker笔记
  • 情人节使用AI TOOL来创建一个甜言蜜语的女伴
  • G-GhostNet(IJCV 2022)原理与代码解析
  • Ethercat系列(5)TWcat3激活过程的协议分析(续1)
  • QT入门Input Widgets之QScrollBar
  • 【ML】基于机器学习的心脏病预测研究(附代码和数据集,多层感知机模型)
  • 工序排序问题--约翰逊法精讲
  • WebDAV之葫芦儿·派盘+网盘精灵
  • 计算机网络期末知识点总结
  • 【Vue3 组件封装】vue3 轮播图组件封装
  • 电力国家(行业)标准目录
  • 如何实现倒序输出