Java 用栈处理四则运算

本文介绍了如何使用Java处理四则运算,通过将中缀表达式转换为后缀表达式,然后计算后缀表达式的结果。步骤包括中缀转后缀(遇到数字输出,处理括号和运算符的优先级),以及后缀表达式的运算(按顺序处理数字和运算符)。整个过程只支持整数的四则运算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概念

中缀表达式:即人们常用的算式写法,如8+(9-1)*8+7/2

后缀表达式:运算符放到数字后,如8 9 1 - 8 * + 7 2 /+


二、思路


一共分两步:

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

从左到右遍历中缀表达式的每一个数字和运算符。
如果数字就输出(即存入后缀表达式);
如果是右括号,则弹出左括号之前的运算符;
如果优先级低于栈顶运算符,则弹出栈顶运算符,并将当前运算符进栈。
遍历结束后,将栈则剩余运算符弹出。


2.后缀表达式计算结果

从左到右遍历后缀表达式,遇到数字就进栈,遇到符号,就将栈顶的两个数字出栈运算,运算结果进栈,直到获得最终结果。


三、代码

目前只支持整数的四则运算

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Stack;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * 目前只能做简单的四则运算,不支持浮点数和其他符号,不支持多线程
 * 计算步骤:
 * 1.中辍表达式转后缀
 * 2.计算后缀表达式
 */
public class Arithmetic {
    /** 错误提示 **/
    private static final String ERROR_ZERO = "DividedZero";
    
    /** 检测一个字符串是不是数字 **/
    private static Pattern pattern = Pattern.compile("\\d+\\.?\\d?");
    
    
    /** 运算符优先级 **/
    private static Map<String, Integer> priority = new HashMap<>();
    static {
        priority.put("*", 2);
        priority.put("/", 2);
        priority.put("+", 1);
        priority.put("-", 1);
        priority.put("", -1); // 无运算符
    }
    
    /** 替换表达式中的中文括号 **/
    private static Map<String, String> replace = new HashMap<>();
    static {
        replace.put("(", "(");
        replace.put(")", ")");
    }
    
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值