C++ Algorithm to Remove Outermost Parentheses

  • 时间:2020-10-05 13:15:44
  • 分类:网络文摘
  • 阅读:116 次

A valid parentheses string is either empty (“”), “(” + A + “)”, or A + B, where A and B are valid parentheses strings, and + represents string concatenation. For example, “”, “()”, “(())()”, and “(()(()))” are all valid parentheses strings. A valid parentheses string S is primitive if it is nonempty, and there does not exist a way to split it into S = A+B, with A and B nonempty valid parentheses strings. Given a valid parentheses string S, consider its primitive decomposition: S = P_1 + P_2 + … + P_k, where P_i are primitive valid parentheses strings. Return S after removing the outermost parentheses of every primitive string in the primitive decomposition of S.

Example 1:
Input: “(()())(())”
Output: “()()()”
Explanation:
The input string is “(()())(())”, with primitive decomposition “(()())” + “(())”.
After removing outer parentheses of each part, this is “()()” + “()” = “()()()”.

Example 2:
Input: “(()())(())(()(()))”
Output: “()()()()(())”
Explanation:
The input string is “(()())(())(()(()))”, with primitive decomposition “(()())” + “(())” + “(()(()))”.
After removing outer parentheses of each part, this is “()()” + “()” + “()(())” = “()()()()(())”.

Example 3:
Input: “()()”
Output: “”
Explanation:
The input string is “()()”, with primitive decomposition “()” + “()”.
After removing outer parentheses of each part, this is “” + “” = “”.

Note:

  • S.length <= 10000
  • S[i] is “(” or “)”
  • S is a valid parentheses string

Tracking the Depth of the Parenthesses

Given the lengthy description, however, the solution is very intuitive/straightforward, i.e. keeping tracks of the depths and ignoring the first level.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class Solution {
public:
    string removeOuterParentheses(string S) {
        string r = "", cur = "";
        int depth = 0;
        for (int i = 0; i < S.size(); ++ i) {
            if (S[i] == '(') {
                depth ++;
                if (depth > 1) {
                    cur += "(";
                }
            } else {
                depth --;
                if (depth == 0) {
                    r += cur;
                    cur = "";
                } else {
                    cur += ")";
                }
            }
        } 
        return r;
    }
};
class Solution {
public:
    string removeOuterParentheses(string S) {
        string r = "", cur = "";
        int depth = 0;
        for (int i = 0; i < S.size(); ++ i) {
            if (S[i] == '(') {
                depth ++;
                if (depth > 1) {
                    cur += "(";
                }
            } else {
                depth --;
                if (depth == 0) {
                    r += cur;
                    cur = "";
                } else {
                    cur += ")";
                }
            }
        } 
        return r;
    }
};

When we meet a left parenthess, we increment the depth, otherwise we decrement the depth i.e. for right parenthess. When the depth is zero for ‘)’, we need to concatenate the inner parenthesses and reset the parenthesses string. The space complexity is O(1) constant and the time complexity for above C++ implementation is O(N) where N is the length of the given input, i.e. a valid parenthesses string.

–EOF (The Ultimate Computing & Technology Blog) —

推荐阅读:
关于报刊亭的数学题  数学题:当甲车到达时,乙车距离工地还有24千米  数学题:光华小学中、高年级共有学生600名  数学题:求大阴影部分的面积  数学题:如何只用这2个水壶从池塘里取得3升的水  关于可能性的数学题  数学题:ABCD乘9等于DCBA,问ABCD各是数字几  数学题:乘积末尾有几个0  求解答:加工一批服装,每天加工300套,16天可以完成  数学题-这个工厂原有男工人多少名 
评论列表
添加评论