1.题目描述
给定一个平衡括号字符串 S,按下述规则计算该字符串的分数:
() 得 1 分。
AB 得 A + B 分,其中 A 和 B 是平衡括号字符串。
(A) 得 2 * A 分,其中 A 是平衡括号字符串。
示例 1:
输入: "()"
输出: 1
示例 2:输入: "(())"
输出: 2
示例 3:输入: "()()"
输出: 2
示例 4:输入: "(()(()))"
输出: 6
提示:
S 是平衡括号字符串,且只含有 ( 和 ) 。
2 <= S.length <= 50
2.解题思路
-
定义一个记录分数的栈,初始时放入 0 当做答案。
-
如果遇到左括号,则 0 入栈。
-
如果遇到右括号,则弹出栈顶;如果此时遍历字符的前一个是左括号,则说明右括号是和上一个左括号相邻的,故此时的栈顶加 1;否则此时的栈顶加 2 * (之前弹出的栈顶)。
-
最后栈中一定还剩一个元素,这个元素就是答案。
附上leetcode题解两种理解:
3.代码实现
class Solution(object):
def scoreOfParentheses(self, S):
"""
:type S: str
:rtype: int
"""
stack=[]
stack.append(0)
for i in range(len(S)):
if S[i] == "(":
stack.append(0)
else:
t=stack.pop(-1)
if S[i-1] == "(":
stack[-1] += 1
else:
stack[-1] += t*2
return stack[-1]