穷举vs暴搜vs深搜vs回溯vs剪枝系列一>括号生成

题目:


解析:

该题:


1.决策树:


2.代码设计:

2.1.全局变量:


2.2.


代码:

java 复制代码
private 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--;
        }
    }
相关推荐
Abelard_20 分钟前
LeetCode--复原IP地址(面试手撕算法高频题)
tcp/ip·算法·leetcode
Joyner201823 分钟前
python-leetcode-买卖股票的最佳时机 II
算法·leetcode·职场和发展
cloud___fly28 分钟前
力扣hot100——堆
算法·leetcode
雾月5539 分钟前
LeetCode 面试题01.04回文排列
算法·leetcode·职场和发展
小徐睡不醒·39 分钟前
Leetcode:h指数
算法·leetcode·职场和发展
23级二本计科44 分钟前
综合练习dfs_1
算法·leetcode·深度优先
L73S371 小时前
栈和队列详解
数据结构·数据库·程序人生·算法·链表·学习方法
晚雾也有归处1 小时前
结构体(C语言)
c语言·开发语言·数据结构·算法
qq_433554541 小时前
C++面向对象编程:纯虚函数、抽象类、虚析构、纯虚析构
开发语言·c++·算法
shadoubuhuijiji1 小时前
C语言——指针和数组名含义的辨析
c语言·算法