题目描述
给定一个只包含 '(' 和 ')' 的字符串,找出最长的包含有效括号的子串的长度。
示例 1:
输入: "(()"
输出: 2
解释: 最长有效括号子串为 "()"
示例 2:
输入: ")()())"
输出: 4
解释: 最长有效括号子串为 "()()"
解题思路一:
对于这种括号匹配问题,一般都是使用栈。
时间复杂度为:O(n)。
空间复杂度为:O(n)。class Solution:
def longestValidParentheses(self, s: str) -> int:
if not s: return 0
res = 0
stack = [-1]
for i in range(len(s)):
if s[i] == "(":
stack.append(i)
else:
stack.pop()
if not stack:
stack.append(i)
else:
res = max(res, i - stack[-1])
return res
1、特判,若s为空,返回0
2、初试化栈stack=[-1],和结果res=0。栈中元素表示上一不匹配位置索引。
3、遍历s:
若s[i]=="("&#x