栈的应用-四则运算(中缀与后缀表达式转换--Java源码)

2024-06-18 16:18

本文主要是介绍栈的应用-四则运算(中缀与后缀表达式转换--Java源码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考链接
结合原文章,做了一定修改,增加Java源码实现

    • 1. 概述
    • 2. 后缀表达式计算
    • 3. 中缀表达式转后缀表达式
    • 4. 源代码实现


1. 概述

对于四则运算表达式的计算,是输入数据结构中栈的应用,即重点是中缀表达式转换为后缀表达式


2. 后缀表达式计算

  • 为了解释后缀表达式的好处,我们先来看看,计算机是如何计算后缀表达式的
  • 后缀表达式实例9 3 1 - 3 * + 10 2 / +
  • 计算规则:从左到右遍历表达式的每个数字和符号,遇到数字就进栈,遇到是符号,就将处于栈顶的两个数字出栈,进行计算,然后计算结果进栈,一直到最终获得结果。
  • 计算过程:


3. 中缀表达式转后缀表达式

我们把平时标准的四则运算表达式比如9+(3-1)*3+10/2叫做中缀表达式。
中缀表达式:9+(3-1)*3+10/2转换后缀表达式9 3 1 - 3 * + 10 2 / +

  • 转换规则

    1. 当当前字符为数字时,直接输出;
    2. 当当前字符为(时,将其压栈;
    3. 当当前字符为)时,则弹出堆栈中最上的(之前的所有运算符并输出,然后删除堆栈中的(
    4. 当当前字符为运算符时,则依次弹出堆栈中优先级大于等于当前运算符的(到”(“之前为止),输出,再将当前运算符压栈;
      最后弹出所有栈中的内容输出
  • 转换过程





4. 源代码实现

package data_structure;import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;/*** 栈的应用* https://blog.csdn.net/u011857433/article/details/79993385* 四则运算表达式求职,中缀表达式与后缀表达式转换*/
public class ReversePoland {public static void main(String[] args) {//        Calculation1("9 3 1 - 3 * + 10 2 / +");System.out.println(Calculation2("9 + ( 3 - 1 ) * 3 + 10 / 2"));}/*** 计算后缀表达式* @param inputString 9 3 1 - 3 * + 10 2 / + 以空格分隔*/public static int Calculation1(String inputString){String[] input = inputString.split(" ");Stack<Integer> stack = new Stack<>();for (int i = 0; i < input.length; i++) {String s = input[i];if (isNumber(s))  //如果是数字,则入栈stack.push(Integer.valueOf(s));else {//遇到运算符,则从栈中弹出两个数字,进行运算int n1 = stack.pop();int n2 = stack.pop();int res = 0;switch (s){case "+":res = n1 + n2;break;case "-":res = n2 - n1;break;case "*":res = n1 * n2;break;case "/":res = n2 / n1;break;}stack.push(res);}}return stack.pop();}/*** 将中缀表达式转化为后缀表达式* @param string 9 + ( 3 - 1 ) * 3 + 10 / 2* @return*/public static String Calculation2(String string){Stack<String> stack = new Stack();String[] chars = string.split(" ");String res = "";for (int i = 0; i < chars.length; i++) {String s = String.valueOf(chars[i]);if (isNumber(s)){if (res.length()==0)res += s;elseres += " "+s;}else {if (s.equals("(")){stack.push(s);}else {if (s.equals(")")){String t = "";String s1 = "";while (!(t = stack.pop()).equals("(")){s1 += " "+t;}res += s1;}else {int priority = getPriority(s);String s1 = "";boolean flag = false;while (!stack.empty()){flag = false;s1 = stack.pop();if (s1.equals("(")){
//                                stack.push("(");break;}if (getPriority(s1) >= priority){res += " " + s1;flag = true;}}if (!s1.equals("") && !flag)stack.push(s1);stack.push(s);}}}}while (!stack.empty()){res += " " + stack.pop();}return res;}//获取运算符的优先级public static int getPriority(String s){Map<String,Integer> map = new HashMap<>();map.put("+",0);map.put("-",0);map.put("*",1);map.put("/",1);map.put("(",2);map.put(")",2);return map.get(s);}public static boolean isNumber(String c){Pattern pattern = Pattern.compile("^(0|[1-9][0-9]*)$");Matcher matcher = pattern.matcher(c);boolean res = matcher.find();return res;}
}

这篇关于栈的应用-四则运算(中缀与后缀表达式转换--Java源码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过