【LeetCode】22. 括号生成

1 问题

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

示例 1:

输入:n = 3

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

示例 2:

输入:n = 1

输出:["()"]

2 答案

这题直接不会

官方解利用回溯算法

深度优先遍历

python 复制代码
class Solution:
    def generateParenthesis(self, n: int) -> List[str]:

        res = []
        cur_str = ''

        def dfs(cur_str, left, right):
            if left ==0 and right == 0:
                res.append(cur_str)
                return
            if left > right:
                return
            if left > 0:
                dfs(cur_str+'(', left-1, right)
            if right > 0:
                dfs(cur_str+')', left, right-1)

        dfs(cur_str, n, n)
        return res
相关推荐
小灰灰爱代码3 小时前
C++——将数组a[5]={-1,2,9,-5,7}中小于0的元素置成0。并将其结果输出(要求:用数组名作为函数的参数来实现)
数据结构·c++·算法
Mopes__4 小时前
Python | Leetcode Python题解之第421题数组中两个数的最大异或值
python·leetcode·题解
liuyang-neu4 小时前
力扣中等 33.搜索旋转排序数组
java·数据结构·算法·leetcode
ganjiee00075 小时前
力扣(leetcode)每日一题 2414 最长的字母序连续子字符串的长度
java·算法·leetcode
ly-how5 小时前
leetcode练习 格雷编码
数据结构·算法·leetcode
远望樱花兔5 小时前
【d44】【Java】【力扣】160.相交链表
java·开发语言·leetcode
阿W呀5 小时前
MATLAB-最小二乘辨识
人工智能·算法·matlab
liuyang-neu5 小时前
力扣 中等 162.寻找峰值
数据结构·算法·leetcode
scott1985125 小时前
张正友相机标定算法
数码相机·算法
临江浪怀柔ℳ5 小时前
tb的数数问题(牛客小白月赛)
算法