逆波兰表达式求值
给你一个字符串数组 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
题解
判断tokens数组值是否为符号,不是符号的话当前值就是数字,直接入栈操作
如果不是数字则说明当前值是符号,从栈取出两个数,(注意:取出来的两个数是用后一个对前一个运算操作,
例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
根据判断的符号进行相应的操作,再把结果入栈,最后栈中只剩一个数,就是计算后的答案。
直接出栈,出栈结果就是所计算的答案。
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();
}
}