题目:
解析:
该题:
1.决策树:
2.代码设计:
2.1.全局变量:
2.2.
代码:
javaprivate List<String> ret; private int left,n,right; private StringBuffer path; public List<String> generateParenthesis(int _n) { n = _n; ret = new ArrayList<>(); path = new StringBuffer(); dfs(); return ret; } private void dfs(){ //递归出口 if(right == n) { ret.add(path.toString()); return; } /** 剪枝写法: */ //添加左括号 if(left < n){ path.append("("); left++; dfs(); //回溯:恢复现场 path.deleteCharAt(path.length()-1); left--; } //添加右括号:右括号永远满足 <= 左括号 if(right < left) { path.append(")"); right++; dfs(); //回溯:恢复现场 path.deleteCharAt(path.length()-1); right--; } }
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>括号生成
robin_suli2024-12-31 15:47
相关推荐
酱酱哥玩AI3 分钟前
Trae编译器:实现多目标班翠鸟优化算法(IPKO)无人机路径规划仿真(Python版),完整代码MPCTHU16 分钟前
二叉树、排序算法与结构图亓才孓22 分钟前
[leetcode]树的操作王禄DUT33 分钟前
化学方程式配平 第33次CCF-CSP计算机软件能力认证wuqingshun31415935 分钟前
蓝桥杯 XYZDreamByte1 小时前
C++菜鸟教程 - 从入门到精通 第五节南玖yy1 小时前
数据结构C语言练习(两个队列实现栈)明朝百晓生1 小时前
【强化学习】【1】【PyTorch】【强化学习简介优化框架】loser~曹1 小时前
基于快速排序解决 leetcode hot215 查找数组中第k大的数字Dream it possible!1 小时前
LeetCode 热题 100_打家劫舍(83_198_中等_C++)(动态规划)