超时与不超时只在两行代码的差别间
class Solution {
public int calculate(String s) {
int res = 0;
int sign = 1;
int len = s.length();
char[] ch = s.toCharArray();
Deque<Integer> stack = new ArrayDeque<>();
for(int i = 0; i < len; i++){
char t = ch[i];
if(Character.isDigit(t)){
int cur = 0;
while(i < len && Character.isDigit(ch[i])){
cur = cur * 10 + (ch[i] - '0');
i++;
}
i--;
res = res + sign * cur;
} else if (t == '+'){
sign = 1;
} else if (t == '-'){
sign = -1;
} else if (t == '('){
stack.push(res);
res = 0;
stack.push(sign);
sign = 1;
} else if (t == ')'){
res = stack.pop() * res + stack.pop();
}
}
return res;
}
}