当前位置: 首页 > news >正文

leetcode22 括号生成-组合型回溯

题目

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

示例

输入:n = 3
输出:[“((()))”,“(()())”,“(())()”,“()(())”,“()()()”]

解析
func generateParenthesis(n int) []string {m := 2 * nans := []string{}var path []bytevar dfs func(i, left int)dfs = func(i, left int) {if i == m {ans = append(ans, string(path))}if left < n {path = append(path, '(')dfs(i+1, left+1)path = path[:len(path)-1]}if i-left < left {path = append(path, ')')dfs(i+1, left)path = path[:len(path)-1]}}dfs(0, 0)return ans
}

这道题有如下细节需要注意,首先是n代表括号的对数,那么就需要乘以2来计算出左括号+右括号数量之和;在dfs逻辑中,如果左括号的数量小于n,则代表还有可以存左括号的位置;i-left其实就是右括号,右括号的数量小于left,表示还可以添加右括号

http://www.lryc.cn/news/348564.html

相关文章:

  • mac定时任务、自启动任务
  • 重磅 | 国家标准《网络安全技术 零信任参考体系架构》正式发布
  • 【C++】可变参数模板简单介绍
  • RabbitMQ--死信队列
  • 微信小程序毕业设计-基于Java后端的微信小程序源码150套(附源码+数据库+演示视频+LW)
  • 提前预知职业天赋!霍兰德职业兴趣测试API接口给你精准推荐
  • js强大的运算符:??、??=
  • 【MATLAB源码-第207期】基于matlab的单相光伏并网系统仿真,并网策略采用基于扰动观测法的MPPT模型和使用电压电流双闭环SPWM控制。
  • java发送请求-二次开发-get请求json
  • Typescript高级: 对泛型和多态的应用, 实现Java中的ArrayList和LinkedList
  • 正则表达式常用特殊字符(元字符)说明
  • 使用hdc TCP模式无线方式连接OpenHarmony设备
  • 杂记-记一次前端打包问题解决过程
  • 维修ABB示教器主板DSQC679 3HAC 033624-001 /R机器人液晶显示屏深圳捷达工控维修
  • 原子学习笔记3——点亮 LED
  • 齐护K210系列教程(十八)_识别条码
  • K折交叉验证
  • Docker 的 Ubuntu 操作系统镜像
  • 【Python】Python中的logging模块介绍和示例
  • PXIe规格i3/i5/i7单板计算机控制器
  • 弱网对抗的策略有哪些?
  • 如何通过OMS加快大表迁移至OceanBase
  • 讨论:WGS84与CGCS2000的坐标系怎么互转
  • SpringCloud面试题
  • 深入了解Java Stream中的Collectors.partitioningBy()
  • 下拉多选【bootstrap-multiselect】
  • 建筑(八大员)报考条件
  • _remote.repositories作用
  • 2.3 Spark运行架构与原理
  • redis的跳表