22. 括号生成

22. 括号生成

回溯

java 复制代码
class Solution {
    List<String> res = new ArrayList<>();
    StringBuilder path = new StringBuilder();  // path推荐这种写法

    public List<String> generateParenthesis(int n) {
        backtrack(n, 0, 0);
        return res;
    }

    void backtrack(int n, int l, int r){
        if(r > l || l > n || r > n) return;
        if(l == n && r == n){
            res.add(path.toString());
            return;
        }

        path.append('(');
        backtrack(n, l + 1, r);
        path.deleteCharAt(path.length() - 1);

        path.append(')');
        backtrack(n, l, r + 1);
        path.deleteCharAt(path.length() - 1);
    }
}
相关推荐
YuTaoShao5 分钟前
【LeetCode 每日一题】1984. 学生分数的最小差值
算法·leetcode·排序算法
Aurora@Hui16 分钟前
FactorAnalysisTool 因子分析工具
人工智能·算法·机器学习
wen__xvn18 分钟前
基础算法集训第06天:计数排序
数据结构·算法·leetcode
(; ̄ェ ̄)。20 分钟前
机器学校入门(十三)C4.5 决策树,CART决策树
算法·决策树·机器学习
Ll130452529823 分钟前
Leetcode哈希表篇
算法·leetcode·散列表
独自破碎E30 分钟前
【字节面试手撕】大数加法
java·算法
鱼跃鹰飞32 分钟前
LeetCode热题100: 49.字母异位词分组
java·数据结构·算法·leetcode
myloveasuka44 分钟前
3-8 译码器(正式型号74LS138、 74HC138、74HCT138 等))
笔记·算法·计算机组成原理·硬件
wen__xvn1 小时前
基础算法集训第17天:二分查找
算法·leetcode·职场和发展
myloveasuka1 小时前
MREQ̅ 信号
笔记·算法·计算机组成原理