LeetCode(python)22.括号生成

题目

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

示例 1:

复制代码
输入:n = 3
输出:["((()))","(()())","(())()","()(())","()()()"]

示例 2:

复制代码
输入:n = 1
输出:["()"]

提示:

  • 1 <= n <= 8

思路

"选与不选":对于每一个左括号都有选或不选,对于每一个右括号都有选或不选,很明显的递归思路

1.递归终止条件:如果选的括号总数 == 2 * n,那么找到一个组合(在递归时使用剪枝,保证所有到达终止条件的组合都合法),存进答案

2.递归单层逻辑:选择左括号的数量 < n,则可以继续选,即处理下一个左括号;选择右括号的数量要 < 左括号的数量,则可以继续选,即处理下一个右括号

3.递归参数:由第二步可知,我们需要知道此时的括号组合、左括号的数量、右括号的数量

代码

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

        def backtrack(temp,l, r):
            if len(temp) == 2 * n:   # 找到一个组合
                res.append(temp)
                return
            if l < n:    # 如果左括号 < n,继续加入左括号,左括号数量+1,递归
                backtrack(temp + '(', l + 1, r)
            if r < l:    # 如果右括号 < 左括号数量,可以加入右括号,右括号数量 + 1,递归
                backtrack(temp + ')', l, r + 1)
        
        backtrack("", 0, 0)
        return res
相关推荐
地平线开发者10 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮10 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者11 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考11 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
孟健13 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
HXhlx14 小时前
CART决策树基本原理
算法·机器学习
码路飞15 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
Wect15 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱15 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
曲幽17 小时前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers