[32. 最长有效括号

32. 最长有效括号

给你一个只包含 '('')' 的字符串,找出最长有效(格式正确且连续)括号子串的长度。

示例 1:

输入:s = "(()"
输出:2
解释:最长有效括号子串是 "()"

示例 2:

输入:s = ")()())"
输出:4
解释:最长有效括号子串是 "()()"

示例 3:

输入:s = ""
输出:0

提示:

  • 0 <= s.length <= 3 * 104
  • s[i]'('')'

思路:

​ 对于最大有效括号长度,只靠一个栈是无法做到的,因此需要添加一个数组来记录到达每个位置时的最大有效括号长度

class Solution {
public:
    int longestValidParentheses(string s) {
        stack<int>st;//记录左括号出现的位置
        int dp[s.size()+1];//dp[i]表示以s[i-1]结尾的最长括号子串
        dp[0]=0;
        for(int i=0;i<s.size();i++){
            if(s[i]=='('){
                st.push(i);
                dp[i+1]=0;//'('不可能是合法括号结尾
            }else{
                //如果是')'
                if(!st.empty()){
                    int leftIndex=st.top();
                    st.pop();
                    int len=1+i-leftIndex+dp[leftIndex];
                    dp[i+1]=len;
                }else{
                    //没有配对左括号
                    dp[i+1]=0;
                }
            }
        }
        int maxL=0;
        for(int i=0;i<s.size()+1;i++){
            maxL=max(maxL,dp[i]);
        }
        return maxL;
    }
};
posted @ 2022-05-13 11:37  BailanZ  阅读(26)  评论(0编辑  收藏  举报