题目:
解析:
该题:
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
相关推荐
吃着火锅x唱着歌1 小时前
LeetCode 1128.等价多米诺骨牌对的数量十八岁讨厌编程2 小时前
【算法训练营 · 补充】LeetCode Hot100(中)橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串wearegogog1232 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法Tiandaren3 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程2301_795167203 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效小当家.1054 小时前
[LeetCode]Hot100系列.贪心总结+思想总结墨雪不会编程4 小时前
数据结构—排序算法篇二ShineWinsu5 小时前
对于数据结构:堆的超详细保姆级解析—上im_AMBER5 小时前
Leetcode 46



