基于Java实现逆波兰(后缀)表达式计算

一、逆波兰(后缀)表达式计算

1.逆波兰表达式,又叫做后缀表达式。什么是逆波兰表达式呢?逆波兰表达式其实是 “操作数写在前面,操作符写在后面”。
比如:3 4 + 5 * 6 -

2.算法描述:
1.)对该表达式扫描,出现的情况就两种,即数字和操作符
2.)如果是数,那么直接入栈
3.)如果是操作符,则弹出两个数,并对其进行计算,再将结果入栈
4.)弹栈计算时,注意操作数的位置,例如:后弹栈的数作被除数,先弹栈的作除数;减法类似

重复以上操作,直到扫描结束,栈中最后保存的结果即为表达式结果,弹栈

3.代码
代码思路:
本代码是基于已有栈进行:
a.首先将表达式进行分割,并保存到集合中;通过集合的遍历完成入栈,计算操作
b.由于集合中的数据类型是String,所以对数计算需要String->Integer的转换
c.这里 判断数的条件是通过 正则表达式 “\\d+” 完成的


import java.util.ArrayList;
import java.util.List;
import java.util.Stack;

public class suffixCalculate {
   

    public static void main(String[] args){
   

        String expression= "3 4 + 5 * 6 -";

        List<String> list = spiltExpression(expression);
        int result 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值