【动态规划】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)。

相关推荐
平凡但不平庸的码农7 小时前
Go Slice 详解
算法·golang
Jasmine_llq10 小时前
《B3867 [GESP202309 三级] 小杨的储蓄》
算法·循环遍历·数组累加(模拟)·索引定位·顺序输出
啦啦啦_999910 小时前
案例之 逻辑回归_电信用户流失预测
算法·机器学习·逻辑回归
风筝在晴天搁浅10 小时前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
DragonnAi11 小时前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer11 小时前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测
灵智实验室12 小时前
PX4状态估计技术EKF2详解(二):EKF2 误差状态动力学与协方差传播
算法·无人机·px 4
米粒112 小时前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇
算法·leetcode·职场和发展
XX風12 小时前
OpenGL中Face culling 面剔除的具体实现
算法·图形渲染
IT猿手13 小时前
光伏模型参数估计:基于山羊优化算法(GOA )的光伏模型参数辨识问题求解研究,免费提供完整MATLAB代码链接
开发语言·算法·matlab·群智能优化算法·智能优化算法·光伏模型参数估计·光伏模型参数辨识