给你一个字符串表达式 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表示一个有效的表达式 -
+不能用作一元运算(例如,+1和+(2 + 3)无效) -
-可以用作一元运算(即-1和-(2 + 3)是有效的) -
输入中不存在两个连续的操作符
-
每个数字和运行的计算将适合于一个有符号的 32位 整数
