「每日LeetCode」2020年12月30日

本文最后更新于:2023年3月19日 晚上

Lt1021. 删除最外层的括号

1021. 删除最外层的括号

有效括号字符串为空 ("")"(" + A + ")"A + B,其中 AB 都是有效的括号字符串,+ 代表字符串的连接。例如,"""()""(())()""(()(()))" 都是有效的括号字符串。
如果有效字符串 S 非空,且不存在将其拆分为 S = A+B 的方法,我们称其为原语(primitive),其中 AB 都是非空有效括号字符串。
给出一个非空有效字符串 S,考虑将其进行原语化分解,使得:S = P_1 + P_2 + ... + P_k,其中 P_i 是有效括号字符串原语。
S 进行原语化分解,删除分解中每个原语字符串的最外层括号,返回 S
示例 1:

1
2
3
4
5
输入:"(()())(())"
输出:"()()()"
解释:
输入字符串为 "(()())(())",原语化分解得到 "(()())" + "(())"
删除每个部分中的最外层括号后得到 "()()" + "()" = "()()()"

示例 2:

1
2
3
4
5
输入:"(()())(())(()(()))"
输出:"()()()()(())"
解释:
输入字符串为 "(()())(())(()(()))",原语化分解得到 "(()())" + "(())" + "(()(()))"
删除每个部分中的最外层括号后得到 "()()" + "()" + "()(())" = "()()()()(())"

示例 3:

1
2
3
4
5
输入:"()()"
输出:""
解释:
输入字符串为 "()()",原语化分解得到 "()" + "()"
删除每个部分中的最外层括号后得到 "" + "" = ""

提示:

  1. S.length <= 10000
  2. S[i]"("")"
  3. S 是一个有效括号字符串

思路

只需要一个储存结果的临时字符串。用 count 计数,为 0 的时候说明是一个原语,截取 start 到下标 i 的就为外层括号里的内容,加入结果字符串中即可。

解答

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/**
* @param {string} S
* @return {string}
*/
var removeOuterParentheses = function (S) {
let count = 0,
start = 1,
res = "";
for (let i = 0; i < S.length; i++) {
if (count === 0) {
start = i + 1;
}
if (S[i] === "(") count++;
else count--;
if (count === 0) {
res += S.slice(start, i);
}
}
return res;
};