给定一个只包含 ‘(’ 和 ‘)’ 的字符串,找出最长的包含有效括号的子串的长度。
示例 1:
输入: “(()”
输出: 2
解释: 最长有效括号子串为 “()”
示例 2:
输入: “)()())”
输出: 4
解释: 最长有效括号子串为 “()()”
思路
首先将字串开始位置start设置为0,建立一个栈,遍历字符串,遇到‘(’便将其位置压入栈中,遇到’)‘时检测栈中有没有储存数据,有的话便弹出。
栈弹出最有三种情况
栈为空,即没有‘(’与’)‘匹配时,字串必然无效,可以舍弃,子串开始位置start设置为当前位置+1
栈弹出后为空,计算当前位置与子串开始位置start的差,即为长度。
栈弹出后不为空,栈顶元素+1即为子串开始的位置。( start不是,因为栈中还有若干个’(‘没匹配 )
代码
def longestValidParentheses(self, s):
l =[]
t=0
start=0
for i in range(len(s)):
if s[i]=='(':l.append(i)
else:
if l==[]:
t=max(t,i-start)
start=i+1
else:
q=l.pop()
if l==[]:t=max(t,i-start+1)
else:t=max(t,i-l[-1])
return t