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

相关推荐
洛水水16 小时前
【力扣100题】16.两两交换链表中的节点
算法·leetcode·链表
wuweijianlove16 小时前
算法教学中的抽象建模与动态可视化设计的技术7
算法
2zcode16 小时前
基于改进YOLO11算法的芯片微缺陷检测系统(UI界面+数据集+分析界面+处置建议+训练代码)
算法·芯片缺陷
leoufung16 小时前
LeetCode 30:Substring with Concatenation of All Words 题解(含 C 语言 uthash 实现)
c语言·leetcode·c#
王老师青少年编程16 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:荷马史诗
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·荷马史诗
样例过了就是过了16 小时前
LeetCode热题100 最小路径和
c++·算法·leetcode·动态规划
Aaron158816 小时前
RFSOC+VU13P+GPU 在6G互联网中的技术应用
大数据·人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理
迷途之人不知返17 小时前
Stack & Queue
c++·算法
没文化的阿浩17 小时前
【数据结构】排序(2)——直接选择排序、堆排序
数据结构·算法·排序算法
ytttr87317 小时前
基于libusb的用户空间UVC相机库
算法