Implement a basic calculator to evaluate a simple expression string.
The expression string contains only non-negative integers, +, -, *, / operators and empty spaces . The integer division should truncate toward zero.
You may assume that the given expression is always valid.
Some examples:
"3+2*2" = 7 " 3/2 " = 1 " 3+5 / 2 " = 5
Note: Do not use the eval built-in library function.
public class Solution {
public int calculate(String s) {
if (s == null || s.length() == 0) {
return 0;
}
Stack<Integer> num = new Stack<>();
Stack<Character> symbol = new Stack<>();
s += "#";
boolean isNum = false;
int cnt = 0;
for (int i = 0; i < s.length(); i++) {
if (s.charAt(i) == ' ') {
continue;
}
char charAt = s.charAt(i);
if (Character.isDigit(charAt)) {
cnt = cnt * 10 + (charAt - '0');
isNum = true;
} else {
if (isNum) {
num.push(cnt);
cnt = 0;
isNum = false;
if (!symbol.isEmpty() && (symbol.peek() == '*' || symbol.peek() == '/')) {
char pop = symbol.pop();
int b = num.pop();
int a = num.pop();
if (pop == '*') {
num.push(a * b);
} else {
num.push(a / b);
}
}
}
if (charAt != '#') {
symbol.push(charAt);
}
}
}
if (!symbol.isEmpty()) {
int tmp = 0;
while (!symbol.isEmpty()) {
Character pop = symbol.pop();
int a = num.pop();
if (pop == '+') {
tmp += a;
} else {
tmp -= a;
}
}
num.push(tmp + num.pop());
}
return num.pop();
}
}
本文将介绍如何使用栈来实现一个简单的计算器,用于评估包含非负整数、加减乘除运算符和空格的基本表达式字符串。通过遍历字符串并使用栈结构,我们可以正确地计算表达式的值,同时遵循整数除法应向下取整的规则。
196

被折叠的 条评论
为什么被折叠?



