LeetCode热题Hot100 - 括号生成

一刷~

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

思路:

递归,考虑手动生成有效括号的逻辑。记录当前可能组合中左括号的个数left和剩余可用括号对数n,1.当left不为0时,加一个右括号,n不变,继续下一个 递归;2.当n不为0时,为当前可能组合加一个左括号,left+1, n-1,继续下一个递归;3.当n=0时,考虑left是否为0,不为0,则在当前可能组合右侧加上left个左括号。

改变递归调用方式,可能更优雅- -

python 复制代码
class Solution:
    def generateParenthesis(self, n: int) -> List[str]:
        res = []
        self.generate(res, '', 0, n)
        return res
    
    def generate(self, res, s, left, n):
        if n == 0:
            if left:
                while left:
                    s += ')'
                    left -= 1
            res.append(s)
            return
        
        if left:
            self.generate(res, s+')', left-1, n)
        self.generate(res, s+'(', left+1, n-1)
相关推荐
weixin_4588726116 小时前
东华复试OJ二刷复盘2
算法
Charlie_lll16 小时前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人16 小时前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
wen__xvn17 小时前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答17 小时前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展
圣保罗的大教堂17 小时前
leetcode 1980. 找出不同的二进制字符串 中等
leetcode
Neteen17 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.17 小时前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区18 小时前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展
再难也得平18 小时前
力扣239. 滑动窗口最大值(Java解法)
算法·leetcode·职场和发展