【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
相关推荐
2301_764441332 小时前
LISA时空跃迁分析,地理时空分析
数据结构·python·算法
东北洗浴王子讲AI2 小时前
GPT-5.4辅助算法设计与优化:从理论到实践的系统方法
人工智能·gpt·算法·chatgpt
Billlly2 小时前
ABC 453 个人题解
算法·题解·atcoder
玉树临风ives2 小时前
atcoder ABC 452 题解
数据结构·算法
feifeigo1233 小时前
基于马尔可夫随机场模型的SAR图像变化检测源码实现
算法
fengfuyao9853 小时前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神4 小时前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜4 小时前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ05 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光5 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生