22. 括号生成
链接
https://leetcode.cn/problems/generate-parentheses/description/
分析
这个题目是让生成有效的括号组合,首先我们搞明白一个问题,什么叫有效的括号?
1. 所有的括号都能找到有效的闭合。
基于此,我们可以认为:左括号数等于右括号数,且从左往后遍历一个序列,已经遍历过的序列中,左括号数始终都大于等于右括号数。 这样才能使所有的括号都能找到有效的闭合。
基于此,我们可以想到2个办法:
1. 我们通过DFS,生成固定长度的所有序列,如果它符合条件,那么我们把它加入到结果值中。
2. 我们通过动态规划的方式。想一个最基本的场景,对于一个有效闭合的序列,我们去给他加一对括号:"()",别管这个括号加在哪个位置,新生成的序列都为有效括号,所以基于此我们可以进行推导。
代码一-DFS
class Solution: def generateParenthesis(self, n: int): res = [] def dfs(left_count, right_count, depth, cur): if depth == n*2: if left_count == right_count: res.append(cur) return if left_count < right_count: # 剪枝 return dfs(left_count+1, right_count, depth+1, cur+'(') dfs(left_count, right_count+1, depth+1, cur+')') dfs(0, 0, 0, '') return res
代码二-动态规划
class Solution: def generateParenthesis(self, n: int): res = ['()'] visited = set(res) for i in range(2, n+1): cur_res = [] for s in res: for j in range(len(s)+1): tmp_s = s[:j] + '()' + s[j:] if tmp_s not in visited: visited.add(tmp_s) cur_res.append(tmp_s) res = cur_res return res
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix