题目:
解析:
该题:
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
相关推荐
Abelard_20 分钟前
LeetCode--复原IP地址(面试手撕算法高频题)Joyner201823 分钟前
python-leetcode-买卖股票的最佳时机 IIcloud___fly28 分钟前
力扣hot100——堆雾月5539 分钟前
LeetCode 面试题01.04回文排列小徐睡不醒·39 分钟前
Leetcode:h指数23级二本计科44 分钟前
综合练习dfs_1L73S371 小时前
栈和队列详解晚雾也有归处1 小时前
结构体(C语言)qq_433554541 小时前
C++面向对象编程:纯虚函数、抽象类、虚析构、纯虚析构shadoubuhuijiji1 小时前
C语言——指针和数组名含义的辨析