题目:
解析:
该题:
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
相关推荐
通信小呆呆8 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?benben0448 小时前
强化学习之DQN算法族(基于gymnasium开发)何以解忧,唯有..9 小时前
Go语言循环语句详解:for、range与循环控制想吃火锅100510 小时前
【leetcode】88.合并两个有序数组js生成论实验室11 小时前
机器人:一个自主运动的系统Qres82111 小时前
算法复键——树状数组H1785350909611 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理不会就选b11 小时前
算法日常・每日刷题--<二分查找>3绿算技术12 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?



