题目:
解析:
该题:
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
相关推荐
靴子学长28 分钟前
Decoder only 架构下 - KV cache 的理解寒秋花开曾相惜1 小时前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)Гений.大天才1 小时前
2026年计算机领域的年度主题与范式转移njidf1 小时前
C++与Qt图形开发ZoeJoy81 小时前
算法筑基(一):排序算法——从冒泡到快排,一文掌握最经典的排序算法qwehjk20081 小时前
代码动态生成技术承渊政道2 小时前
【优选算法】(实战体会位运算的逻辑思维)Frostnova丶2 小时前
LeetCode 2573. 找出对应 LCP 矩阵的字符串承渊政道2 小时前
【优选算法】(实战推演模拟算法的蕴含深意)林鸿群2 小时前
实现支持纳秒级精度的时间引擎(C++)



