题目描述:
Evaluate the value of an arithmetic expression in Reverse Polish Notation.
Valid operators are+,-,*,/. Each operand may be an integer or another expression.
Some examples:
["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) -> 9
["4", "13", "5", "/", "+"] -> (4 + (13 / 5)) -> 6
代码实现:
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
public class Solution {
public static int evalRPN(String[] tokens){
String operators = "+-*/";
Stack<String> stack = new Stack<String>();
for (String str : tokens) {
if(!operators.contains(str)){//如果是操作数,入栈
stack.push(str);
}else{//如果是操作符,弹出栈顶两个元素做运算
int a = Integer.valueOf(stack.pop());
int b = Integer.valueOf(stack.pop());
switch(str){
case "+":
stack.push(String.valueOf(a+b));
break;
case "-":
stack.push(String.valueOf(b-a));
break;
case "*":
stack.push(String.valueOf(a*b));
break;
case "/":
stack.push(String.valueOf(b/a));
break;
}
}
}
return Integer.valueOf(stack.pop());
}
public static void main(String[] args) {
String[] tokens = new String[]{"2", "1", "+", "3", "*"};
System.out.println(evalRPN(tokens));
}
}