Java 逆波兰表达式求值

逆波兰表达式求值

给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。

请你计算该表达式。返回一个表示表达式值的整数。

注意:

  • 有效的算符为 '+''-''*''/'

  • 每个操作数(运算对象)都可以是一个整数或者另一个表达式。

  • 两个整数之间的除法总是 向零截断

  • 表达式中不含除零运算。

  • 输入是一个根据逆波兰表示法表示的算术表达式。

  • 答案及所有中间计算结果可以用 32 位 整数表示。

示例 1:

输入:tokens = ["2","1","+","3","*"]

输出:9

解释:该算式转化为常见的中缀算术表达式为:((2 + 1) * 3) = 9

示例 2:

输入:tokens = ["4","13","5","/","+"]

输出:6

解释:该算式转化为常见的中缀算术表达式为:(4 + (13 / 5)) = 6

示例 3:

输入:tokens = ["10","6","9","3","+","-11","*","/","*","17","+","5","+"]

输出:22

解释:该算式转化为常见的中缀算术表达式为:

((10 * (6 / ((9 + 3) * -11))) + 17) + 5

= ((10 * (6 / (12 * -11))) + 17) + 5

= ((10 * (6 / -132)) + 17) + 5

= ((10 * 0) + 17) + 5

= (0 + 17) + 5

= 17 + 5

= 22

题解

  1. 判断tokens数组值是否为符号,不是符号的话当前值就是数字,直接入栈操作

  1. 如果不是数字则说明当前值是符号,从栈取出两个数,(注意:取出来的两个数是用后一个对前一个运算操作,

例num2-num1。1-2*3 =》后缀式123*-,栈数据{1,2,3}

num1=3,num2=2 符号 *

res=num2*num1=2*3=6,栈数据{1,6}

num1=6,num2=1 符号 -

res=num2-num1=1-6=-5

根据判断的符号进行相应的操作,再把结果入栈,最后栈中只剩一个数,就是计算后的答案。

  1. 直接出栈,出栈结果就是所计算的答案。

class Solution {
    public int evalRPN(String[] tokens) {
       Stack<Integer> stack = new Stack<>();
        for (int i = 0; i < tokens.length; i++) {
            if(!tokens[i].equals("+") && !tokens[i].equals("-") && !tokens[i].equals("*")
                    && !tokens[i].equals("/")){
                stack.push(Integer.parseInt(tokens[i]));
            }else {
                int num1 = stack.pop();
                int num2 = stack.pop();
                if(tokens[i].equals("+")){
                    stack.push(num2+num1);
                }else if(tokens[i].equals("-")){
                    stack.push(num2-num1);
                }else if(tokens[i].equals("*")){
                    stack.push(num2*num1);
                }else if(tokens[i].equals("/")){
                    stack.push(num2/num1);
                }
            }
        }
        // System.out.println(stack.pop());
        return stack.pop();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值