Implement a basic calculator to evaluate a simple expression string.
The expression string may contain open ( and closing parentheses ), the plus + or minus sign -, non-negative integers and empty spaces .
You may assume that the given expression is always valid.
Some examples:
"1 + 1" = 2
" 2-1 + 2 " = 3
"(1+(4+5+2)-3)+(6+8)" = 23
注意:运算符只有加减,用sign表示
Simple iterative solution by identifying characters one by one. One important thing is that the input is valid, which means the parentheses are always paired and in order.
Only 5 possible input we need to pay attention:
digit: it should be one digit from the current number
'+': number is over, we can add the previous number and start a new number
'-': same as above
'(': push the previous result and the sign into the stack, set result to 0, just calculate the new result within the parenthesis.
')': pop out the top two numbers from stack, first one is the sign before this pair of parenthesis, second is the temporary result before this pair of parenthesis. We add them together.
Finally if there is only one number, from the above solution, we haven't add the number to the result, so we do a check see if the number is zero.
public int calculate(String s) {
Stack<Integer> stack = new Stack<Integer>();
int result = 0;
int number = 0;
int sign = 1;
for(int i = 0; i < s.length(); i++){
char c = s.charAt(i);
if(Character.isDigit(c)){
number = 10 * number + (int)(c - '0');
}else if(c == '+'){
result += sign * number;
number = 0;
sign = 1;
}else if(c == '-'){
result += sign * number;
number = 0;
sign = -1;
}else if(c == '('){
//we push the result first, then sign;
stack.push(result);
stack.push(sign);
//reset the sign and result for the value in the parenthesis
sign = 1;
result = 0;
}else if(c == ')'){
result += sign * number;
number = 0;
result *= stack.pop(); //stack.pop() is the sign before the parenthesis
result += stack.pop(); //stack.pop() now is the result calculated before the parenthesis
}
}
if(number != 0) result += sign * number;
return result;
}
二刷
首先要弄清楚几个变量的含义。
res是当前括号内的运算结果
sign是上一个符号,所以遇到当前符号的时候,要先res+= sign*num
num是当前的value, 遇到'(', '+', '-'要重新置为0
public class Solution {
public int calculate(String s) {
int sign = 1;
int res = 0;
Stack<Integer> stack = new Stack<>();
int num = 0;
for(int i=0; i<s.length(); i++){
char ch = s.charAt(i);
if(Character.isDigit(ch)){
num = num*10 + ch - '0';
}else if(ch == '+'){
res += sign*num;
sign = 1;
num = 0;
}else if(ch == '-'){
res += sign*num;
sign = -1;
num = 0;
}else if(ch == '('){
stack.push(res);
stack.push(sign);
sign = 1;
res = 0;
}else if(ch == ')'){
res += sign*num;
num = 0;
res = stack.pop()*res + stack.pop();
}
}
if(num!=0){
res += sign*num;
}
return res;
}
}