LeetCode.22。括号生成

题目描述:

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

输入输出实例:

思路:对于这道题目我们可以用回溯法,创建一个函数backtrack(当前字符,左括号数量,右括号数量),这个函数用来递归生成所有的括号组成可能。我们先前创立一个空列表,在backtrack递归过程中满足条件的我们放到列表中,最后返回列表。

在backtrack中,如果当前的字符组成满足长度等于2*n的时候,我们得到一个有效的括号组成,将其加到ans列表;如果当前左括号比n少,我们继续添加左括号;如果当前右括号比左括号少,我们添加右括号。

比如当n==2时候,我们先是添加一个左括号->再添加左括号->再添加右括号->再添加右括号->满足条件将'(())'存入ans。然后返回到'('尝试添加右括号(即'()')->再添加左括号->再添加右括号->将'()()'存入ans->递归结束,return ans

python 复制代码
class Solution:
    def generateParenthesis(self, n: int) -> List[str]:
        #构建函数backtrack用来构建有效括号组合
        def backtrack(s:str,left:int,right:int):
            #达到目标长度放入
            if len(s) == 2*n:
                ans.append(s)
                return
            
            #左括号数量不够可加左括号
            if left < n :
                backtrack(s+'(',left+1,right)
            
            #右括号不足加右括号
            if right < left :
                backtrack(s+')',left,right+1)
            

        ans = []
        backtrack('',0,0)
        return ans
相关推荐
এ᭄画画的北北14 分钟前
力扣-287.寻找重复数
算法·leetcode
Deng9452013141 小时前
基于Python的职位画像系统设计与实现
开发语言·python·文本分析·自然语言处理nlp·scrapy框架·gensim应用
FreakStudio5 小时前
一文速通 Python 并行计算:13 Python 异步编程-基本概念与事件循环和回调机制
python·pycharm·协程·多进程·并行计算·异步编程
豌豆花下猫7 小时前
让 Python 代码飙升330倍:从入门到精通的四种性能优化实践
后端·python·ai
夏末蝉未鸣017 小时前
python transformers库笔记(BertForTokenClassification类)
python·自然语言处理·transformer
YuTaoShao8 小时前
【LeetCode 热题 100】141. 环形链表——快慢指针
java·算法·leetcode·链表
小小小新人121239 小时前
C语言 ATM (4)
c语言·开发语言·算法
weixin_418813879 小时前
Python-可视化学习笔记
笔记·python·学习
Danceful_YJ9 小时前
4.权重衰减(weight decay)
python·深度学习·机器学习
你的冰西瓜9 小时前
C++排序算法全解析(加强版)
c++·算法·排序算法