关于算法:32最长有效括号-算法leetode附思维导图-全部解法300题

44次阅读

共计 1842 个字符,预计需要花费 5 分钟才能阅读完成。

零 题目:算法(leetode,附思维导图 + 全副解法)300 题之(32)最长无效括号

一 题目形容

二 解法总览(思维导图)

三 全副解法

1 计划 1

1) 代码:

// 计划 1“滑动窗口法”。// 通过:229 / 231,超时!// 例子:太长,暂不列举。// 思路:// 1)初始化状态。// 2)外围:窗口大小固定为 tempL(范畴:[l, 0]),一直穷举所有的可能状况、而后做解决
// tempL:以后窗口大小,left、right 别离为以后窗口的左右边。// 3)返回后果
var longestValidParentheses = function(s) {
    // 判断以后子串 tempS 是否为 无效括号
    const isValidParentheses = (tempS = '') => {
        const l = tempS.length;
        let stack = [];

        for (let i = 0; i < l; i++) {if (tempS[i] === '(') {stack.push('(');
            }
            else {const tempChar = stack.pop();
                if (tempChar !== '(') {return false;}
            }
        }

        return stack.length === 0;
    };

    // 1)初始化状态。const l = s.length;

    // 2)外围:窗口大小固定为 tempL(范畴:[l, 0]),一直穷举所有的可能状况、而后做解决
    // tempL:以后窗口大小,left、right 别离为以后窗口的左右边。for (let tempL = l; tempL > 0; tempL--) {
        // 优化:长度为奇数,必定不是!if (tempL % 2 === 1) {continue;}

        for (let left = 0; left < (l - tempL + 1); left++) {const right = (left + tempL - 1);
            // 优化:最左、最右的字符肯定别离是 '('、')'!if (s[left] !== '(' || s[right] !== ')') {continue;}
            else {const tempS = s.slice(left, right + 1);
                if (isValidParentheses(tempS)) {
                    // 3)返回后果
                    return tempL;
                }
            }
        }
    }

    // 3.2)返回后果
    return 0;
};

2 计划 2

1) 代码:

// 计划 2“动静布局”。// 思路:// 1)咱们用 dp[i] 示意以 i 结尾的最长无效括号
// 2.1)若 s[i] 为 (,则 dp[i] 必然等于 0,因为不可能组成无效的括号
// 2.2)若 s[i] 为 ),// 2.2.1)且当 s[i-1] 为 (,则 dp[i] = dp[i-2] + 2;// 2.2.2)且当 s[i-1] 为 ) && s[i-dp[i-1] - 1] 为 (,则 dp[i] = dp[i-1] + 2 + dp[i-dp[i-1]-2]。// 3)返回后果 resLength 
// 参考:// 1)https://leetcode-cn.com/problems/longest-valid-parentheses/solution/dong-tai-gui-hua-si-lu-xiang-jie-c-by-zhanganan042/
var longestValidParentheses = function(s) {
    // 1)状态初始化
    const l = s.length;
    let dp = Array(l).fill(0),
        resLength = 0;

    // 2)外围:// 1)咱们用 dp[i] 示意以 i 结尾的最长无效括号
    // 2.1)若 s[i] 为 (,则 dp[i] 必然等于 0,因为不可能组成无效的括号
    // 2.2)若 s[i] 为 ),// 2.2.1)且当 s[i-1] 为 (,则 dp[i] = dp[i-2] + 2;// 2.2.2)且当 s[i-1] 为 ) && s[i-dp[i-1] - 1] 为 (,则 dp[i] = dp[i-1] + 2 + dp[i-dp[i-1]-2]。for (let i = 0; i < l; i++) {if (i > 0 && s[i] === ')') {if (s[i - 1] === '(') {dp[i] = ((i - 2 >= 0) ? dp[i - 2] + 2 : 2);
            }
            else if (s[i - 1] === ')' && (i - dp[i - 1] - 1 >= 0) && (s[i- dp[i - 1] - 1] === '(')) {dp[i] = dp[i - 1] + 2 + (i - dp[i - 1] - 2 >= 0 ? dp[i - dp[i - 1] - 2] : 0);
            }
        }
        resLength = Math.max(resLength, dp[i]);
    }

    // 3)返回后果 resLength 
    return resLength;
}

正文完
 0