class Solution {
public:
int calculate(string s) {
}
};
224. 基本计算器
给你一个字符串表达式 s
,请你实现一个基本计算器来计算并返回它的值。
注意:不允许使用任何将字符串作为数学表达式计算的内置函数,比如 eval()
。
示例 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
表示一个有效的表达式"+(2 + 3)"
无效)"-(2 + 3)"
是有效的)原站题解
python3 解法, 执行用时: 116 ms, 内存消耗: 15.4 MB, 提交时间: 2022-08-10 16:35:04
class Solution: def calculate(self, s: str) -> int: ops = [1] sign = 1 ret = 0 n = len(s) i = 0 while i < n: if s[i] == ' ': i += 1 elif s[i] == '+': sign = ops[-1] i += 1 elif s[i] == '-': sign = -ops[-1] i += 1 elif s[i] == '(': ops.append(sign) i += 1 elif s[i] == ')': ops.pop() i += 1 else: num = 0 while i < n and s[i].isdigit(): num = num * 10 + ord(s[i]) - ord('0') i += 1 ret += num * sign return ret