(LC)基本计算器

224. 基本计算器

实现一个基本的计算器来计算一个简单的字符串表达式 s 的值。

示例 1:

输入:s = “1 + 1”
输出:2
示例 2:

输入:s = " 2-1 + 2 "
输出:3
示例 3:

输入:s = “(1+(4+5+2)-3)+(6+8)”
输出:23

提示:

1 <= s.length <= 3 * 105
s 由数字、’+’、’-’、’(’、’)’、和 ’ ’ 组成
s 表示一个有效的表达式

 public int calculate(String s) {
    
    
        Deque<Integer> ops = new LinkedList<Integer>();
        ops.push(1);
        int sign = 1;

        int ret = 0;
        int n = s.length();
        int i = 0;
        while (i < n) {
    
    
            if (s.charAt(i) == ' ') {
    
    
                i++;
            } else if (s.charAt(i) == '+') {
    
    
                sign = ops.peek();
                i++;
            } else if (s.charAt(i) == '-') {
    
    
                sign = -ops.peek();
                i++;
            } else if (s.charAt(i) == '(') {
    
    
                ops.push(sign);
                i++;
            } else if (s.charAt(i) == ')') {
    
    
                ops.pop();
                i++;
            } else {
    
    
                long num = 0;
                while (i < n && Character.isDigit(s.charAt(i))) {
    
    
                    num = num * 10 + s.charAt(i) - '0';
                    i++;
                }
                ret += sign * num;
            }
        }
        return ret;
    }

猜你喜欢

转载自blog.csdn.net/weixin_45567738/article/details/114646668