有效括号字符串为空 ("")、"(" + A + “)” 或 A + B,其中 A 和 B 都是有效的括号字符串,+
代表字符串的连接。例如,"","()","(())()" 和 “(()(()))” 都是有效的括号字符串。如果有效字符串 S 非空,且不存在将其拆分为 S = A+B 的方法,我们称其为原语(primitive),其中 A 和 B
都是非空有效括号字符串。给出一个非空有效字符串 S,考虑将其进行原语化分解,使得:S = P_1 + P_2 + … + P_k,其中 P_i
是有效括号字符串原语。对 S 进行原语化分解,删除分解中每个原语字符串的最外层括号,返回 S 。
示例 1:
输入:"(()())(())" 输出:"()()()" 解释: 输入字符串为 “(()())(())”,原语化分解得到 “(()())” +
“(())”, 删除每个部分中的最外层括号后得到 “()()” + “()” = “()()()”。 示例 2:输入:"(()())(())(()(()))" 输出:"()()()()(())" 解释: 输入字符串为
“(()())(())(()(()))”,原语化分解得到 “(()())” + “(())” + “(()(()))”,
删除每个部分中的最外层括号后得到 “()()” + “()” + “()(())” = “()()()()(())”。 示例 3:输入:"()()" 输出:"" 解释: 输入字符串为 “()()”,原语化分解得到 “()” + “()”,
删除每个部分中的最外层括号后得到 “” + “” = “”。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-outermost-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
每对括号里的字符需要输出出来,所以在遇到左括号时我们将左括号压入栈保存起来,接着向后循环,当遇到的值不是右括号并且栈不为空,代表此时为括号内的值,输出该值,接着循环,遇到右括号,则证明该括号内所有值输出完毕,将栈内的左括号弹栈。
class Solution {
public:
string removeOuterParentheses(string S) {
string res = "";
stack<char> mystack;
for (int i = 0; i < S.size(); i++) {
if (S[i] == ')')
mystack.pop();
if (!mystack.empty())
res+=S[i];
if (S[i] == '(')
mystack.push('(');
}
return res;
}
};