代码拉取完成,页面将自动刷新
# coding: utf-8
from typing import List
from parso import parse
class Solution:
# 只有加法和减法和括号
# 使用两个栈
def calculate(self, s: str) -> int:
op = []
nums = []
i = 0
while i < len(s):
ch = s[i]
if ch == '(':
continue
elif ch == ')':
sum = nums[-1]+nums[-2]
nums.pop()
nums.pop()
nums.append(sum)
i = i + 1
elif ch == '-':
num, i = self.changeInt(s, i+1)
nums.append(-1 * num)
op.append('+')
elif ch == '+':
num, i = self.changeInt(s, i+1)
nums.append(num)
op.append('-')
elif ch == ' ' or (ch >= '0' and ch <= '9'):
num, i = self.changeInt(s, i)
nums.append(num)
num = 0
def changeInt(self, s: str, begin: int) -> int:
ans = 0
i = begin
while i < len(s) and s[i] != '+' and s[i] != '-' and s[i] != '(' and s[i] != ')':
if(s[i] >= '0' and s[i] <= '9'):
ans = ans*10 + int(s[i])
i = i+1
return ans, i
if __name__ == '__main__':
solu = Solution()
print(solu.calculate('1+ 2 -1-2'))
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。