150. Evaluate Reverse Polish Notation

Evaluate Reverse Polish Notation

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

Solution

public class Solution {
 public int evalRPN(String[] tokens) {
        Stack<String> stack = new Stack<>();

        for(String s:tokens) {
            switch (s) {
                case "+":
                case "-":
                case "*":
                case "/":
                    int a = Integer.valueOf(stack.pop());
                    int b = Integer.valueOf(stack.pop());

                    int c = a+b;
                    if (s.equals("-")) {
                        c = b - a;
                    } else if (s.equals("*")) {
                        c = a*b;
                    } else if (s.equals("/")) {
                        c = b / a;
                    }

                    stack.push(String.valueOf(c));

                    break;

                default:
                    stack.push(s);
                    break;
            }
        }

        return Integer.valueOf(stack.pop());
    }
}

Last updated