[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 @   BailanZ  阅读(28)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示