逆波兰表达式中缀表达式转换为后缀表达式

中缀表达式转换为后缀表达式

思路分析

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EY4i1xoB-1616239469589)(C:\Users\王东梁\AppData\Roaming\Typora\typora-user-images\image-20210320170359134.png)]

代码实现

package com.atguigu.stack;import javax.swing.plaf.nimbus.State;
import java.security.AlgorithmConstraints;
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;/*** @创建人 wdl* @创建时间 2021/3/20* @描述*/
public class PolandNotation {public static void main(String[] args) {//完成一个中缀表达式转换成后缀表达式的功能//说明//1."1+((2+3)×4)-5"=>"1 2 3 + 4 × + 5 –"//2.因为直接对一个str进行操作,不方便,因此先将"1+((2+3)×4)-5"=>中缀的表达式对应的List//即"1+((2+3)×4)-5"=>ArrayList[....//3.将得到的中缀表到时对应的List转换成后缀表达式ListString expression="1+((2+3)*4)-5";List<String> infixExpressionList = toInfixExpressionList(expression);System.out.println("中缀表达式对应的List"+infixExpressionList);List<String> parseSuffixExpreesionList = parseSuffixExpreesionList(infixExpressionList);System.out.println("后缀表达式对应的List"+parseSuffixExpreesionList);System.out.println("expression="+calculate(parseSuffixExpreesionList));//        //先定义一个逆波兰表达式
//        // (3+4)×5-6 对应的后缀表达式就是 3 4 + 5 × 6 -
//        //说明为了方便,逆波兰表达式的数字和符号使用空格隔开
//        String suffixExpression="3 4 + 5 * 6 -";
//        //思路
//        //1.先将"3 4 + 5 × 6 -"放到ArrayList中
//        //2.将ArrayList传递给一个方法,遍历ArrayList配合栈完成计算
//        List<String> rpnList=getListString (suffixExpression);
//        System.out.println(rpnList);
//
//        int res=calculate(rpnList);
//        System.out.println("计算的结果是="+res);}public static List<String> parseSuffixExpreesionList(List<String> ls){//定义两个栈Stack<String> s1=new Stack<String>();//符号栈//说明:因为s2这个栈,在整个转换过程中,没有pop操作,而且我们后面还需要逆序输出//因此比较麻烦,这里我们就不用Stack<String>直接使用List<String> s2//Stack<String> s2=new Stack<String>();存储中间结果的栈s2List<String> s2 = new ArrayList<>();//存储中间结果的List2//遍历lsfor(String item:ls){//如果是一个数,加入到s2if (item.matches("\\d+")){s2.add(item);}else if (item.equals("(")){s1.push(item);}else if(item.equals(")")){//如果是右括号“)”,则依次弹出s1栈顶的运算符,并压入s2,// 直到遇到左括号为止,此时将这一对括号丢弃while (!s1.peek().equals("(")){s2.add(s1.pop());}s1.pop();//!!!将(弹出s1栈,消除小括号}else{//当item的优先级小于等于栈顶运算符的优先级,将s1栈顶的运算符弹出并加入到s2中,// 再次转到(4.1)与s1中新的栈顶运算符相比较;//问题:我们缺少一个比较优先级高低的方法while (s1.size()!=0&&Operation.getValue(s1.peek()) >= Operation.getValue(item)){s2.add(s1.pop());}//还需要将item压入栈s1.push(item);}}//将s1中剩余的运算符依次弹出并加入s2while (s1.size()!=0){s2.add(s1.pop());}return s2;//注意因为是存放到List,因此按顺序输出就是对应的后缀表达式对应的List}//方法:将中缀表达式转换成对应的Listpublic static List<String> toInfixExpressionList(String s){//定义一个List,存放中缀表达式对应的内容List<String> ls = new ArrayList<>();int i=0;//这时是一个指针,用于遍历中缀表达式字符串String str;//对多位数的拼接工作char c;//每遍历一个字符,就放入到cdo{//如果c是一个非数字,我们就需要加入到lsif((c=s.charAt(i))<48||(c=s.charAt(i))>57){ls.add(c+"");i++;//i需要后移}else {//如果是一个数,需要考虑多位数str="";//先将str置成""while (i<s.length()&&((c=s.charAt(i))>=48&&(c=s.charAt(i))<=57)){str+=c;//拼接i++;}ls.add(str);}}while (i<s.length());return ls;//返回}//将一个逆波兰表达式,依次将数据和运算符放到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;}//完成对逆波兰表达式的运算
//    从左至右扫描,将3和4压入堆栈;
//    遇到+运算符,因此弹出4和3(4为栈顶元素,3为次顶元素),计算出3+4的值,得7,再将7入栈;
//    将5入栈;
//    接下来是×运算符,因此弹出5和7,计算出7×5=35,将35入栈;
//    将6入栈;
//    最后是-运算符,计算出35-6的值,即29,由此得出最终结果public static int calculate(List<String> ls){//创建一个栈,只需要一个栈即可Stack<String> stack = new Stack<>();//遍历 lsfor(String item:ls){//这里使用正则表达式来取出数if(item.matches("\\d+")){//匹配的是多位数//入栈stack.push(item);}else {//pop出两个数,并运算,再入栈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+"");}}//最后留在stack中的数据就是运算结果return Integer.parseInt(stack.pop());}}//编写一个类Operation返回一个运算符对应的优先级
class Operation{private static int ADD=1;private static int SUB=1;private static int MUL=2;private static int DIV=2;//写一个方法,返回对应的优先级数字public static int getValue(String operation){int result=0;switch (operation){case "+":result=ADD;break;case "-":result=SUB;break;case "*":result=MUL;break;case "/":result=DIV;break;default:System.out.println("不存在该运算符");break;}return result;}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326939.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OSS.Common扩展.Net Standard支持实例分享

上篇&#xff08;.Net基础体系和跨框架开发普及&#xff09;介绍了.Net当前生态下的大概情况&#xff0c;也分享了简单实现的过程&#xff0c;这篇文章就是讲解我的OSS.Common项目扩展.Net Standard 支持的过程&#xff0c;主要集中在&#xff1a;方案的选择&#xff0c;移植检…

A configuration error occurred during startup.Please verify the preference field with the prompt: To

今天遇到了一个棘手的问题&#xff0c;到现在都没有解决&#xff0c;折腾了一天结果捣鼓出来个更棘手的问题&#xff0c;经过多方继续折腾&#xff0c;终于把后来的这个问题给搞定了&#xff0c;但是前面的问题还是没有解决。有遇到相类似的问题解决了的麻烦分享一下&#xff0…

150. 逆波兰表达式求值---JAVA---LeetCode

class Solution {public int evalRPN(String[] tokens) {//创建一个栈&#xff0c;只需要一个栈即可Stack<Integer> stack new Stack<>();//遍历 lsfor(String item:tokens){//这里使用正则表达式来取出数if(isNumber(item)){//匹配的是多位数//入栈stack.push(In…

look look C#7

vs2017也rc好几个版本了&#xff0c;本想跟进看看c#7加入了什么内容&#xff0c;去搜索c#7&#xff0c;确实找到了不少文章&#xff0c;无奈很多特性ide根本不让编译啊。。。所以今天主要列出已经确定了的c#7特性&#xff08;一般来说rc后也不会加入新的特性了&#xff0c;其它…

jQuery Raty星级评分插件使用方法

转载自 jQuery Raty星级评分插件使用方法 使用jQuery Raty&#xff0c;可以很方便的在页面上嵌入一个评分组件&#xff0c;如下所示&#xff1a; 使用方法很简单&#xff0c;首先从https://github.com/wbotelhos/raty下载raty的源代码&#xff08;依赖于jquery&#xff09; …

迷宫问题---递归解决

题目描述 代码实现 package com.atguigu.recursion;/*** 创建人 wdl* 创建时间 2021/3/21* 描述*/ public class MiGong {public static void main(String[] args) {//先创建一个二维数组&#xff0c;模拟迷宫//地图int[][] map new int[8][7];//使用1表示墙//上下全部置为1f…

20周年献礼:Visual Studio 2017正式版3月7日发布

微软透露 Visual Studio 2017 的开发工作已经接近尾声&#xff0c;即将进入 RTM 阶段。现在&#xff0c;微软正式宣布&#xff0c;Visual Studio 2017 正式版将于 3 月 7 日正式发布&#xff01;值得一提的是&#xff0c;今年正好是 Visual Studio 诞生 20 周年纪念。 为了表示…

JDK环境变量配置(一次性成功)

1.变量名&#xff1a; JAVA_HOME 变量值&#xff1a;&#xff08;变量值填写你的jdk的安装目录&#xff0c;例如本人是 E:\Java\jdk1.8.0&#xff09; 2.变量名&#xff1a; Path 变量值&#xff1a; ;%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin; 3.变量名&#xff1a; CLASSPATH …

jquery插件star-rating.js实现星级评分特效

转载自 jquery插件star-rating.js实现星级评分特效 Bootstrap Star Rating是一个简单而强大的jQuery插件实现星级分数评级。支持像分数星填充和RTL输入先进的功能。在利用纯CSS-3造型使控制重点开发。该插件使用引导标记和造型默认情况下&#xff0c;但它可以覆盖与其他任何C…

C#winforms实现windows窗体人脸识别

在之前我写过一篇博客&#xff0c;是关于javaweb实现人脸识别&#xff0c;包括数据库以及java源码&#xff0c;还有相关的jar包都已经上传了&#xff0c;有想要了解的可以去看看&#xff0c;地址是&#xff1a;java实现人脸识别源码 实现了之后又正好朋友开发C#&#xff0c;想要…

OSS.Common获取枚举字典列表标准库支持

上篇&#xff08;.Net Standard扩展支持实例分享&#xff09;介绍了OSS.Common的标准库支持扩展&#xff0c;也列举了可能遇到问题的解决方案。由于时间有限&#xff0c;同时.net standard暂时还没有提供对DescriptionAttribute的支持&#xff0c;所以其中的转化枚举到字典列表…

程序员的情人节礼物:当天微软开始Build 2017登记

2016 年 12 月&#xff0c;微软曾经宣布 Build 2017 大会将于 2017 年 5 月 10 日至 12 日在美国西雅图举行&#xff1b;时隔两个月&#xff0c;关于 Build 2017 大会的消息&#xff0c;终于有了新的进展。 2 月 10 日&#xff0c;微软在官方博客中宣布 Build 2017 大会将开启注…

查找前端依赖 jquery css js 时间控件 不要用远程依赖 会变化的 card

BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务 找到你要的版本

使用VS Code从零开始开发调试.NET Core 1.1

使用VS Code 从零开始开发调试.NET Core 1.1。无需安装VS 2017 RC 即可开发调试.NET Core 1.1应用。 .NET Core 1.1 发布也有一段时间了&#xff0c;最大的改动是从 project.json 还原回了csproj 。 今天微软发布 .NET Core SDK 1.0 RC4 版本&#xff0c;离RTM版本也很近了。 对…

冒泡排序+推导过程

推导过程 代码实现 package com.atguigu.sort;import java.util.Arrays;/*** 创建人 wdl* 创建时间 2021/3/21* 描述*/ public class BubbleSort {public static void main(String[] args) {int arr[]{3,9,-1,10,-2};//为了容易理解&#xff0c;我们吧冒泡排序的演变过程给大家…

.Net Core 之 MSBuild 介绍

前言 关于 .NET Core 旧版本的 sdk 介绍可以参看我以前的 这篇 文章。 8 个小时前&#xff0c;.NET Core 项目组释放了 .NET Core 新一轮的 sdk 工具更新&#xff0c;即 RC4 版本 &#xff0c;这个版本也就是意味着基本功能已经确定了&#xff0c;下个版本应该就是RTM版了&…

mysql加索引快很多

3秒 变成 0.1秒 左连接的字段加索引 order by字段加索引 频繁使用的检索字段加索引

jQuery 基础教程 (四)之jQuery中的DOM操作

一、jQuery 中的 DOM 操作 &#xff08;1&#xff09;DOM(Document Object Model—文档对象模型)&#xff1a;一 种与浏览器, 平台, 语言无关的接口, 使用该接口可以 轻松地访问页面中所有的标准组件 &#xff08;2&#xff09;DOM 操作的分类: (A)DOM Core: DOM Core 并不专…