22. 括号生成

作者: 莫小鹏 | 来源:发表于2018-09-18 21:30 被阅读0次

题目描述

给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。

例如,给出 n = 3,生成结果为:

[
  "((()))",
  "(()())",
  "(())()",
  "()(())",
  "()()()"
]

分析

观察规律,构造结果。
n表示括号对数,
左边符号(,右边的符号),构造时:
当左边的符号数为n时,构造完成,直接补全右边的符号。
添加左边符号,递归生成余下的部分。
需要满足的条件,左边的符号数>右边的符号数。
添加右边符号,递归生成余下的部分。

代码

class Solution {
public:
    void doGenParenthesis(int n, string str, int left, int right, vector<string>& vec) {
        if(left == n) {
            vec.push_back(str.append(n - right, ')'));
            return;
        }
        doGenParenthesis(n, str + '(', left + 1, right, vec);
        if(left <= right)
            return;
        doGenParenthesis(n, str + ')', left, right + 1, vec);
    }
    
    vector<string> generateParenthesis(int n) {
        vector<string> vec;
        if(n <=0) {
            return vec;
        }
        doGenParenthesis(n, "", 0, 0, vec);
        return vec;
    }
};

题目链接

https://leetcode-cn.com/problems/generate-parentheses/description/

相关文章

  • LeetCode-22. 括号生成

    参考:第7课-泛型递归、树的递归 LeetCode-22. 括号生成 22. 括号生成 数字 n 代表生成括号的对...

  • LeetCodeDay51 —— 括号生成★★☆

    22. 括号生成 描述 给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。...

  • leetcode(python)22.括号生成

    22.括号生成 给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。 例如,...

  • 22. 括号生成

    22. 括号生成[https://leetcode.cn/problems/generate-parenthese...

  • [day7] [LeetCode] [title22,3,26]

    22.括号生成 给出n代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。 例如,给出...

  • 每周 ARTS 第 24 期

    1. Algorithm 22. 生成括号(中等) 描述: 给出 n 代表生成括号的对数,请你写出一个函数,使其能...

  • LeetCode:22. 括号生成

    问题链接 22. 括号生成[https://leetcode.cn/problems/generate-paren...

  • 22. 括号生成

    给出n代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。 例如,给出n=3,生成结果...

  • 22. 括号生成

    知乎ID: 码蹄疾码蹄疾,毕业于哈尔滨工业大学。小米广告第三代广告引擎的设计者、开发者;负责小米应用商店、日历、开...

  • 22. 括号生成

    题目描述 给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。 例如,给出 ...

网友评论

    本文标题:22. 括号生成

    本文链接:https://www.haomeiwen.com/subject/fsdvnftx.html