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);
    }
}
相关推荐
孤飞38 分钟前
zero2Agent:面向大厂面试的 Agent 工程教程,从概念到生产的完整学习路线
算法
技术专家2 小时前
Stable Diffusion系列的详细讨论 / Detailed Discussion of the Stable Diffusion Series
人工智能·python·算法·推荐算法·1024程序员节
csdn_aspnet2 小时前
C# (QuickSort using Random Pivoting)使用随机枢轴的快速排序
数据结构·算法·c#·排序算法
鹿角片ljp2 小时前
最长回文子串(LeetCode 5)详解
算法·leetcode·职场和发展
paeamecium4 小时前
【PAT甲级真题】- Cars on Campus (30)
数据结构·c++·算法·pat考试·pat
chh5635 小时前
C++--模版初阶
c语言·开发语言·c++·学习·算法
RTC老炮5 小时前
带宽估计算法(gcc++)架构设计及优化
网络·算法·webrtc
dsyyyyy11015 小时前
计数孤岛(DFS和BFS解决)
算法·深度优先·宽度优先
会编程的土豆6 小时前
01背包与完全背包详解
开发语言·数据结构·c++·算法
汀、人工智能6 小时前
[特殊字符] 第86课:最大正方形
数据结构·算法·数据库架构·图论·bfs·最大正方形