22. 括号生成

简介: 22. 括号生成

数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。

示例 1:

输入:n = 3

输出:["((()))","(()())","(())()","()(())","()()()"]

示例 2:

输入:n = 1

输出:["()"]

class Solution(object):
    def generateParenthesis(self, n):
        res = []
        def backtrack(in_idx, out_idx, tmp_res):
            if out_idx > n or in_idx > n:
                return
            if len(tmp_res) == 2*n:
                res.append(tmp_res)
                return
            if n-in_idx:
                backtrack(in_idx+1, out_idx, tmp_res+'(')
            if in_idx-out_idx:
                backtrack(in_idx, out_idx+1, tmp_res+')')
        backtrack(0,0,'')
        return res


相关文章
|
6月前
字符串括号匹配
字符串括号匹配
|
5月前
20. 有效的括号
20. 有效的括号
|
6月前
22. 括号生成
22. 括号生成
47 4
|
5月前
22.括号生成
22.括号生成
|
6月前
|
C++
去括号问题(C++处理)
去括号问题(C++处理)
75 0
LeetCode:有效的括号
LeetCode:有效的括号
50 0
|
6月前
leetcode:有效的括号
leetcode:有效的括号
Leetcode20.有效的括号
Leetcode20.有效的括号
29 0
|
数据安全/隐私保护 Python
一日一技:一个括号两种意思,正则表达式奇怪的小括号
一日一技:一个括号两种意思,正则表达式奇怪的小括号
86 0