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

189 阅读1分钟

一、题目描述:

1) 任何一个左括号都能找到和其正确配对的右括号
2) 任何一个右括号都能找到和其正确配对的左括号
问:如果括号无效,至少返回几个字符能让其整体有效

示例:

示例 1:

输入:(())
输出:0

示例 2:

输入:(()
输出:1

示例 3:

输入:))
输出:2

示例 3:

输入:()))((()
输出:4

二、思路分析:

定义需要补充')'的括号个数need,'('的个数count。使用count,记录'('的个数,当遇到')'时,执行减一操作。每循环一次,判断一下count是否为负数,如果为负的话,需要补充的个数加一,再将count变为0即可。

例: s='())('

image.png

结果应该是所需要')'的括号个数need,再加上'('多余的个数count。

三、AC 代码:

function isValid(s) {
  let count = 0,
    need = 0
  for (let i = 0; i < s.length; i++) {
    count += s[i] === '(' ? 1 : -1
    if (count === -1) {
      need++
      count = 0
    }
  }
  return need + count
}

四、总结:

尽量考虑简单、高效的方法。使用两个变量,一个记录所需')'数,一个记录'('多余为撇配的个数。