题目:
解析:
该题:
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
相关推荐
91刘仁德13 小时前
c++类和对象(下)diediedei13 小时前
模板编译期类型检查阿杰学AI13 小时前
AI核心知识78——大语言模型之CLM(简洁且通俗易懂版)mmz120714 小时前
分治算法(c++)睡一觉就好了。14 小时前
快速排序——霍尔排序,前后指针排序,非递归排序Tansmjs14 小时前
C++编译期数据结构金枪不摆鳍14 小时前
算法-字典树diediedei14 小时前
C++类型推导(auto/decltype)独断万古他化15 小时前
【算法通关】前缀和:从一维到二维、从和到积,核心思路与解题模板loui robot15 小时前
规划与控制之局部路径规划算法local_planner



