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


相关文章
|
5月前
字符串括号匹配
字符串括号匹配
|
5月前
|
Java C++ Python
leetcode-20:有效的括号
leetcode-20:有效的括号
53 0
|
4月前
20. 有效的括号
20. 有效的括号
|
5月前
22. 括号生成
22. 括号生成
40 4
|
4月前
22.括号生成
22.括号生成
|
5月前
|
C++
去括号问题(C++处理)
去括号问题(C++处理)
46 0
|
5月前
|
C++
HRBUST - 1170(判断括号是否匹配)
HRBUST - 1170(判断括号是否匹配)
|
11月前
|
C语言 C++
20.有效的括号(LeetCode)
20.有效的括号(LeetCode)