题目:
解析:
该题:
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
相关推荐
修己xj38 分钟前
探索设计模式的宝库:Java-Design-Patterns鲨鱼辣椒_TUT41 分钟前
MySQL连接算法和小表驱动大表的原理设计师小聂!1 小时前
力扣热题100------21.合并两个有序链表এ᭄画画的北北2 小时前
力扣-1.两数之和shenghaide_jiahu2 小时前
数学建模——递归和动态规划凯子坚持 c3 小时前
动态规划专题:详解二维费用背包问题——以“一和零”与“盈利计划”为例黑色的山岗在沉睡3 小时前
P1948 [USACO08JAN] Telephone Lines S快去睡觉~4 小时前
力扣301:删除无效的括号技术炼丹人5 小时前
从RNN为什么长依赖遗忘到注意力机制的解决方案以及并行