LeetCode224:基本计算器(栈)
解题思路:
1、双栈模拟,一个用来存数,一个用来存操作符。需要考虑 '('后面紧跟'+'、'-'这种情况
2、递归:遇到左括号开始递归,遇到右括号结束递归,返回值。
1 class Solution:
2 def calculate(self, s):
3 s = '('+s+')'
4 stack = []
5 op = []
6 val = 0
7 flag = False
8 for i in range(len(s)):
9 if ord('0')<=ord(s[i])<=ord('9'):
10 val=val*10+ord(s[i])-ord('0')
11 flag= True
12 elif s[i]=='(':
13 op.append('(')
14 stack.append('(')
15 elif s[i]==')':
16 if flag:
17 stack.append(val)
18 flag = False
19 val = 0
20 ans = 0
21 while op[-1]!='(' and stack[-1]!='(':
22 if op[-1]=='+':
23 ans = ans + stack[-1]
24 elif op[-1]=='-':
25 ans = ans - stack[-1]
26 _,_= stack.pop(),op.pop()
27
28 if op[-1]=='(' and stack[-1]=='(':
29 _ = op.pop(),stack.pop()
30 elif op[-1]=='(':
31 ans+=stack[-1]
32 _ = stack.pop()
33 _ = op.pop(), stack.pop()
34 else:
35 print('error')
36 exit()
37 stack.append(ans)
38 elif s[i]=='+':
39 if flag:
40 stack.append(val)
41 flag=False
42 val = 0
43 op.append('+')
44 elif s[i]=='-':
45 if flag:
46 stack.append(val)
47 flag =False
48 val=0
49 op.append('-')
50 elif s[i]==' ':
51 continue
52 return stack[-1]
53 s = Solution().calculate("0+0+(-0+0)")
54 print(s)
LeetCode224:基本计算器(栈)的更多相关文章
- hiho #1332 : 简单计算器 栈+递归
#1332 : 简单计算器 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 编写一个程序可以完成基本的带括号的四则运算.其中除法(/)是整除,并且在负数除法时向0取整.( ...
- F - 简单计算器(栈)
F - 简单计算器 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descripti ...
- HDU-1237- 简单计算器--栈的基本应用
简单计算器 Problem Description 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. Input 测试输入包含若干测试用例,每个测试用例占一行,每行不 ...
- HDU 1237 简单计算器 栈
额,题目是中文的,题意就不用说了= =都看懂喽.写个字符串先把这行计算式存进去,不过不能存一个算一个,因为考虑到乘除法比加减法优先的原则,如果是加号减号就先存着等待计算,如果是乘号除号就直接算出来值就 ...
- [Swift]LeetCode224. 基本计算器 | Basic Calculator
Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...
- hdoj--1237--简单计算器(栈模拟)
简单计算器 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm ...
- HDU1237 简单计算器 栈
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237 题目大意:读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. 题目分 ...
- hdu-1237简单计算器(栈的运用)
http://acm.hdu.edu.cn/showproblem.php?pid=1237 简单的栈的运用. 首先将数字和运算符分离,分别保存在两个数组中,然后按原来的式子的顺序,首先将第一个数和第 ...
- LeetCode224 基本计算器
idea:刚开始是打算分类讨论,建立了数字栈和字符栈,按照传入字符当时两个栈的基本情况分类,结果讨论完之后分类太麻烦,导致分析完了之后漏洞不少.我觉得这道题难点在于括号和负号的处理,一开始将导致计算机 ...
- HDU题解索引
HDU 1000 A + B Problem I/O HDU 1001 Sum Problem 数学 HDU 1002 A + B Problem II 高精度加法 HDU 1003 Maxsu ...
随机推荐
- iFiles浏览iphone文件
我们希望能在iphone中浏览文件系统的目录
- [htmlayout] csss! 改变值/文本
<input type="text" value="123" /> <div class="test">内容内容&l ...
- Servlet 上
Servlet 1.什么是Servlet Servlet即Server Applet是运行在Web服务器端的小程序 2.创建Servlet的三种方式 注意:从Tomcat10.0以后,我们统一用 ja ...
- Azure Data Factory(八)数据集验证之服务主体(Service Principal)
一,引言 如下图所示,今天我们接着上一篇内容,继续讲解 Azure Data Factory 中的数据集连接服务的认证方式:Service Principal 关于 Service Principal ...
- @Validated指定校验顺序
在Java中,使用@NotNull注解时,可以指定多个参数的顺序.为了指定顺序,你可以使用@GroupSequence注解. 首先,为每个需要校验的参数定义一个接口,并在接口上添加@GroupSequ ...
- Solution -「YunoOI 2007」rfplca
Description Link. Given is a rooted tree with the \(\sf1\)-th node as the root. The tree will be giv ...
- destoon关于archiver归档的性能优化
今天在处理一个项目时候发现archiver单个模块归档超过百万数据,打开速度就特慢,所以打开archiver下index.php文件进行分析,发现有句sql作怪 1 $result = $db-> ...
- Python经典编程题40题(二)
Python经典编程题40题(二) 题目 给你一个list L, 如 L=[2,8,3,50], 对L进行降序排序并输出, 如样例L的结果为[50,8,3,2] 输入示例 输入:L = [4, ...
- JavaCore extends Plugin
/******************************************************************************* 2 * Copyright (c) 2 ...
- [SUCTF 2019]CheckIn 1
看到字符upload 就想到了文件上传漏洞 就先上传一个一句话木马试试 似乎直接上传不成功,可能是有什么过滤 再上传一个包含一句话木马的图片试试 发现提示不能是图片,这时候就不会了,在网上找了一下wp ...

