栈的应用:实现逆波兰计算器

2024-06-02 13:12
文章标签 实现 应用 波兰 计算器

本文主要是介绍栈的应用:实现逆波兰计算器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开篇

本篇文章是学习数据结构过程中的笔记,所以有时代码可能不够完整,会在后续的学习中记录下更完整的代码版本。

思路分析

后缀表达式又称逆波兰表达式,与前缀表达式类似,只是运算符位于操作数之后
举例说明:(3+4)*5-6对应的后缀表达式就是3 4 + 5 * 6 -
后缀表达式的计算机求值过程:
从左至右扫描表达式,遇到数字时,将数字压入栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(次顶元素和栈顶元素),并将结果入栈;重复上述过程直到表达式的最右端,最后运算得出的值即为表达式的结果。
例如: (3+4)*5-6对应的后缀表达式就是 3 4 + 5 * 6 - ,针对后缀表达式求值步骤如下:

  1. 从左至右扫描,将3和4压入堆栈;
  2. 遇到+运算符,因此弹出4和3(4为栈顶元素,3为次顶元素),计算出3+4的值,得7,再将7压入栈;
  3. 将5入栈;
  4. 接下来是运算符,因此弹出5和7,计算出57 = 35, 将35入栈;
    5.将6入栈;
  5. 最后是-运算符,计算出35-6的值,即29,因此得出最终结果

代码实现

package com.zyc.stack;import java.util.ArrayList;
import java.util.List;
import java.util.Stack;public class PolandNotation {public static void main(String[] args) {// (3+4)*5-6  => 3 4 + 5 * 6 -// (30 - 6 ) / 3 * 8 = 64String suffixExpression = "30 6 - 3 / 8 *";// 1. 先将表达式放入到ArrayList中// 2.将ArrayList传递给一个方法,遍历ArrayList配合栈完成计算List<String> list = getListString(suffixExpression);System.out.println("list="+list);int res = calculate(list);System.out.println("运算结构是: " + res);}/*** 完成对逆波兰表达式的计算* 从左至右扫描,将3和4压入堆栈;* 遇到+运算符,因此弹出4和3(4是栈顶元素,3是次顶元素),计算出3+4的值,得7,再将7入栈;* 将5入栈;* 接下来是*运算符,因此弹出5和7,计算出5*7=35, 将35入栈* 将6入栈* 最后是-运算符,计算出35-6的值,即29,因此得出最终结果* @param list* @return*/public static int calculate(List<String> list) {// 创建栈Stack<String> stack = new Stack<>();// 遍历for (String item :list) {// 这里使用正则来取出数if (item.matches("\\d+")) {// 数字入栈stack.push(item);} else {// 如果是运算符,则弹出两个数字,并运算,并把运算结果入栈int num2 = Integer.parseInt(stack.pop());int num1 = Integer.parseInt(stack.pop());int res = 0;if (item.equals("+")) {res = num1 + num2;} else if(item.equals("-")) {res = num1 - num2;} else if(item.equals("*")) {res = num1 * num2;} else if(item.equals("/")) {res = num1 / num2;} else {throw new RuntimeException("运算符错误");}// res入栈stack.push("" + res);}}// 最后留在栈中的就是运算结果return Integer.parseInt(stack.pop());}// 将一个逆波兰表达式,依次将数据和运算符放入到ArrayList中public static List<String> getListString(String suffixExpression) {// 将suffixExpression分割String[] split = suffixExpression.split(" ");List<String> list = new ArrayList<>();for(String ele: split) {list.add(ele);}return list;}
}

以上便是使用栈实现计算器的思路和代码,希望对您有所帮助。
感谢阅读!

这篇关于栈的应用:实现逆波兰计算器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1024062

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

亮相WOT全球技术创新大会,揭秘火山引擎边缘容器技术在泛CDN场景的应用与实践

2024年6月21日-22日,51CTO“WOT全球技术创新大会2024”在北京举办。火山引擎边缘计算架构师李志明受邀参与,以“边缘容器技术在泛CDN场景的应用和实践”为主题,与多位行业资深专家,共同探讨泛CDN行业技术架构以及云原生与边缘计算的发展和展望。 火山引擎边缘计算架构师李志明表示:为更好地解决传统泛CDN类业务运行中的问题,火山引擎边缘容器团队参考行业做法,结合实践经验,打造火山

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

探索蓝牙协议的奥秘:用ESP32实现高质量蓝牙音频传输

蓝牙(Bluetooth)是一种短距离无线通信技术,广泛应用于各种电子设备之间的数据传输。自1994年由爱立信公司首次提出以来,蓝牙技术已经经历了多个版本的更新和改进。本文将详细介绍蓝牙协议,并通过一个具体的项目——使用ESP32实现蓝牙音频传输,来展示蓝牙协议的实际应用及其优点。 蓝牙协议概述 蓝牙协议栈 蓝牙协议栈是蓝牙技术的核心,定义了蓝牙设备之间如何进行通信。蓝牙协议

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa