关闭

Leetcode#22 Generate Parentheses

115人阅读 评论(0) 收藏 举报
分类:

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;
    }


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:30124次
    • 积分:3268
    • 等级:
    • 排名:第10411名
    • 原创:311篇
    • 转载:4篇
    • 译文:0篇
    • 评论:1条
    文章分类
    最新评论