括号有效配对一箭三连(三)

简介: 1) 任何一个左括号都能找到和其正确配对的右括号2) 任何一个右括号都能找到和其正确配对的左括号返回一个括号字符串中,最长的括号有效子串长度

一、题目描述:


1) 任何一个左括号都能找到和其正确配对的右括号

2) 任何一个右括号都能找到和其正确配对的左括号

返回一个括号字符串中,最长的括号有效子串长度


示例:

示例 1:

输入:(()))

输出:4


示例 2:

输入:()(()))

输出:6  


示例 3:

输入:)()())

输出:4  


二、思路分析:


当问到最长有多少时,可以考虑使用动态规划去实现。定义一个辅助数组dp,用于记录字符串当前字符最大有效括号长度。


遍历字符串

1、当遇到'('时,最长有效字符串长度为0;

2、当遇到')'时,就需要看前面一个dp的值


如果i-1最长有效长度为0

  • i-2前面没有字符,那么i位置的有效长度就为2;
  • i-2前面还有字符,有效长度就为2 + dp[i-dp[i-1]-1]。


如果i-1最长有效长度为不为0

  • 就要追溯到i-1位置最长有效长度的前一位,判断该位是不是可以和当前匹配,如果可以就需要加上dp[i-dp[i-1]-1],即2+ dp[i-dp[i-1]-1] + dp[i-1]。(例:s='(()())', s[5]可以和s[0]匹配,有效长度为2 + 0 + 4 = 6)


总之,抽象起来就是:看第i-1个有效字符串长度是否等于'(',等于就需要看第i-1个有效字符串长度的前一位,前一位存在就需要加上,不存在就不需要加。例: s='()()))'

网络异常,图片无法展示
|

例: s=')(()())'

网络异常,图片无法展示
|


三、AC 代码:


function maxLength(s) {
  if (s == null || s.length < 2) return 0
  let dp = new Array(s.length).fill(0)
  let max = 0
  for (let i = 0; i < s.length; i++) {
    if (s[i] === ')') {
      let pre = i - dp[i - 1] - 1
      if (s[pre] === '(' && pre >= 0) {
        dp[i] = dp[i - 1] + 2 + (pre > 0 ? dp[pre - 1] : 0)
      }
    }
    max = Math.max(max, dp[i])
  }
  console.log(dp)
  return max
}


四、总结:


遇到最值问题,将问题抽象成以什么什么开头或结尾,求其i-1位置的值。再考虑包的含情况及关系等式。


作者:ClyingDeng

链接:https://juejin.cn/post/6951262583894573087

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
相关文章
|
5天前
|
C++
HRBUST - 1170(判断括号是否匹配)
HRBUST - 1170(判断括号是否匹配)
|
11天前
C的if...else..配对
C的if...else..配对
7 0
|
23天前
|
算法 测试技术 C#
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
【字符串】【括号匹配】【广度优先】301. 删除无效的括号
|
4月前
|
存储 算法 C++
括号序列:使用C++检查括号有效性
括号序列:使用C++检查括号有效性
24 0
|
10月前
蓝桥——括号合法组合 2020-11-26
蓝桥——括号合法组合 2020-11-26
|
算法 前端开发 JavaScript
【前端算法】判断一个字符串的括号是否成对匹配
使用typescript完成判断一个字符串的括号是否成对匹配的过程
用户输入括号是否匹配
用户输入括号是否匹配
43 0
用户输入括号是否匹配
|
前端开发 JavaScript 算法
有效的括号,成对字符合法性检测
每日算法练习,今天一起来看看“有效的括号,成对字符合法性检测”。
226 0
|
存储 算法
算法题-字符串中的有效括号
算法题-字符串中的有效括号
141 0