LeetCode热题100 最长有效括号

题目描述

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

左右括号匹配,即每个左括号都有对应的右括号将其闭合的字符串是格式正确的,比如 "(()())"。

示例 1:

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

示例 2:

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

示例 3:

输入 :s = ""
输出:0

提示:

0<=s.length<=3∗1040 <= s.length <= 3 * 10^40<=s.length<=3∗104

s[i] 为 '(' 或 ')'

思路

使用动态规划,考虑以每个位置结尾的答案最大值。具体的步骤见代码。

代码

cpp 复制代码
class Solution {
public:
    int longestValidParentheses(string s) {
        int n = s.length();
        vector<int> dp(n); // 以i结尾的答案最大值

        int res = 0;
        for(int i = 0; i < n; ++i)
        {
            // (结尾的不是答案
            if(s[i] == ')') 
            {
                // 上一个是(, 直接合并
                if(i > 0 && s[i - 1] == '(')
                {
                    dp[i] = (i >= 2 ? dp[i - 2] : 0) + 2;
                }
                // 上一个是), 看看上一个合并的前一个数不是(, 是的话可以合并
                else if(i > 0 && s[i - 1] == ')' && i - dp[i - 1] - 1 >= 0 && s[i - dp[i - 1] - 1] == '(' )
                {
                    dp[i] = dp[i - 1] + (i - dp[i - 1] - 2 >= 0 ? dp[i - dp[i - 1] - 2] : 0) + 2;
                }
            }
            res = max(res, dp[i]);
        }

        return res;
    }
};
相关推荐
吃好睡好便好21 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅1 天前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
于小猿Sup1 天前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
x_yeyue1 天前
三角形数
笔记·算法·数论·组合数学
念何架构之路1 天前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星1 天前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
小小编程路1 天前
C++ 多线程与并发
java·jvm·c++
失去的青春---夕阳下的奔跑1 天前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光1 天前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩1 天前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up