【LeetCode热题100(86/100)】最长有效括号

题目地址: 链接

状态转移方程:
d p [ i + 1 ] = { d p [ i − 1 ] + 2 , 若 s [ i ] = ′ ) ′ 且 s [ i − 1 ] = ′ ( ′ d p [ i ] + 2 + d p [ i − d p [ i ] − 1 ] , 若 s [ i ] = ′ ) ′ 且 s [ i − 1 ] = ′ ) ′ 且 s [ i − 1 − d p [ i ] ] = ′ ( ′ 0 , 其他情况 dp[i+1] = \begin{cases} dp[i-1] + 2, & \text{若 } s[i] = ')' \text{ 且 } s[i-1] = '(' \\ dp[i] + 2 + dp[i - dp[i] - 1], & \text{若 } s[i] = ')' \text{ 且 } s[i-1] = ')' \text{ 且 } s[i-1-dp[i]] = '(' \\ 0, & \text{其他情况} \end{cases} dp[i+1]=⎩ ⎨ ⎧dp[i−1]+2,dp[i]+2+dp[i−dp[i]−1],0,若 s[i]=′)′ 且 s[i−1]=′(′若 s[i]=′)′ 且 s[i−1]=′)′ 且 s[i−1−dp[i]]=′(′其他情况

TS 复制代码
/*
 * @lc app=leetcode.cn id=32 lang=typescript
 *
 * [32] 最长有效括号
 */

// @lc code=start
function longestValidParentheses(s: string): number {
    let n = s.length;
    const dp = new Array(n + 1).fill(0);
    let ans = 0;
    for(let i = 1; i < n; i ++) {
        if(s[i] == ')') {
            if(s[i - 1] == '(') dp[i + 1] = dp[i - 1] + 2;
            if(s[i - 1] == ')' && s[i - 1 - dp[i]] == '(') {
                dp[i + 1] = dp[i] + 2 + dp[i - dp[i] - 1]
            }
        }
        ans = Math.max(dp[i + 1], ans);
    }
    return ans;
};
// @lc code=end
相关推荐
AI软著研究员4 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish4 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱5 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者21 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮21 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者1 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考1 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx1 天前
CART决策树基本原理
算法·机器学习
Wect1 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱1 天前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法