Leetcode#22 Generate Parentheses

Difficulty: Medium

Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses.

For example, given n = 3, a solution set is:

"((()))", "(()())", "(())()", "()(())", "()()()"

方法是递归/回溯,这个很容易想到,但是算法比较难以理清,看完清晰题解之后才理清楚。

具体的方法是通过两个int le 和ri 来记录'('和‘)'的剩余个数,递归赋值,列遍所有可能,算法非常巧妙。

void gen(int le, int ri, string s, vector<string>& ans){
    if(le==0&&ri==0)
        ans.push_back(s);
    if(le>0){
        gen(le-1,ri,s+'(',ans);
    }
    if(ri>le&&ri>0){
        gen(le,ri-1,s+')',ans);
    }

}

vector<string> generateParenthesis(int n) {
          vector<string> ans;
          string s;
          gen(n,n,s,ans);
          return ans;
    }


阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011472124/article/details/46797577
个人分类: 暑假备战UVa Leetcode
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

Leetcode#22 Generate Parentheses

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭