【动态规划】Leetcode 32. 最长有效括号【困难】

最长有效括号

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

示例 2:

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

解题思路

  • 1、使用动态规划求解,定义一个一维数组dp,其中dp[i]表示以第i个字符结尾的最长有效括号子串的长度。
  • 2、初始化dp数组,将所有元素初始化为0。
  • 3、从第二个字符开始遍历字符串,对于每个字符:
    如果当前字符是')',且前一个字符是'(',
复制代码
   则更新dp[i] = dp[i-2] + 2。

如果当前字符是')',且前一个字符是')',且以第i-1个字符结尾的最长有效括号子串的前一个字符是'('(即i-dp[i-1]-1处的字符是'('),
*

复制代码
   则更新dp[i] = dp[i-1] + dp[i-dp[i-1]-2] + 2。
  • 4、遍历dp数组,找出其中的最大值作为结果返回。

java实现

java 复制代码
public class LongestValidParentheses {
    public int longestValidParentheses(String s) {
        int n = s.length();
        int[] dp = new int[n];
        int maxLen = 0;

        for (int i = 1; i < n; i++) {
            if (s.charAt(i) == ')') {
                if (s.charAt(i - 1) == '(') {
                    //大于2,证明除了当前()字符之外,前面还有额外的字符
                    //需要额外字符的有效括号长度dp[i-2]+2
                    //否则为0+2
                    dp[i] = (i >= 2 ? dp[i - 2] : 0) + 2;
                } else if (i - dp[i - 1] > 0 && s.charAt(i - dp[i - 1] - 1) == '(') {
                    //i - dp[i - 1] >= 2 判断'('前面是否还有字串
                    //若前面还有串则需要加上前面的串的有效括号长度dp[i - dp[i - 1] - 2]
                    //=1只有本身的串了 直接加0
                    //最后加上新增的一对括号的长度
                    dp[i] = dp[i - 1] + (i - dp[i - 1] >= 2 ? dp[i - dp[i - 1] - 2] : 0) + 2;
                }
                maxLen = Math.max(maxLen, dp[i]);
            }
        }

        return maxLen;
    }

    public static void main(String[] args) {
        LongestValidParentheses solution = new LongestValidParentheses();
        String s = "((()))())()";
        System.out.println("Longest valid parentheses length: " + solution.longestValidParentheses(s)); // Output: 4
    }
}

时间空间复杂度

  • 时间复杂度:遍历了一次字符串s,时间复杂度为O(n),其中n为字符串s的长度。

  • 空间复杂度:使用了一个一维数组dp,空间复杂度为O(n)。

相关推荐
小O的算法实验室14 小时前
2025年SEVC,面向进化计算的学习注入式优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
啊我不会诶14 小时前
2024北京市赛补题
c++·算法
shehuiyuelaiyuehao14 小时前
算法13,滑动窗口,水果成篮
算法·哈希算法·散列表
智慧物业老杨14 小时前
物业数智化转型实战:从单一服务到综合解决方案的技术落地路径
人工智能·算法·ai
夏末蝉未鸣0114 小时前
Sort-Merge Join【排序连接算法】详解(python代码实现,以FULL JOIN为例)
数据结构·算法
tjl521314_2114 小时前
01C++ 分离编译与多文件编程
前端·c++·算法
_日拱一卒14 小时前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展
哆啦刘小洋14 小时前
【LeetCode每日一题】:2033(贪心+快速排序魔改)
算法·leetcode
WolfGang00732114 小时前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
cheems952714 小时前
[算法手记] 动态规划 ,二维费用限制背包问题如何处理
算法·动态规划