力扣热门100题之括号生成

核心思路

只有两条规则:

  1. 左括号:只要没到 n,随便加
  2. 右括号 :必须 少于左括号 才能加(保证不出现 ()) 这种非法情况)

回溯过程就是:

先加 (

尝试加 )

不行就回溯

凑够长度就保存

完整代码实现:

java 复制代码
class Solution {
    List<String> res = new ArrayList<>();
    public List<String> generateParenthesis(int n) {
        // 回溯:当前字符串、左括号数量、右括号数量、n
        backtrack("",0,0,n);
        return res;
    }
    public void backtrack(String path,int open,int close,int n){
        // 出口:总长度 == 2 * n 说明凑够一对了
        if(path.length() == 2*n){
            res.add(path);
            return;
        }
        //左括号没满 -> 可以加左括号
        if(open < n){
            backtrack(path + "(",open + 1,close,n);
        }

        if(close < open){
            backtrack(path + ")",open,close + 1,n);
        }
    }
}

总结

左括号随便加,右括号只能比左括号少,凑够长度就是合法答案。

相关推荐
淡海水15 分钟前
【AI模型】模型量化技术详解
人工智能·算法·机器学习
炸膛坦客17 分钟前
嵌入式 - 数据结构与算法:(1-1)数据结构 - 顺序表(Sequential List)
数据结构·算法·嵌入式
水龙吟啸26 分钟前
数据结构与算法随机复习–Day1
数据结构·c++·算法
生成论实验室38 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第八篇:认知与反思关系——探索、定位与延续
人工智能·算法·架构·知识图谱·创业创新
YaraMemo1 小时前
一文带你区分全局最优解和帕累托最优解
算法·5g·信息与通信·信号处理
白夜11171 小时前
C++(标签派发 Tag Dispatching)
开发语言·c++·笔记·算法
YaraMemo2 小时前
数学优化问题中的三大转化:多目标转化为单目标,多变量转化为单变量,有约束转化为无约束
人工智能·算法·5g·信息与通信·信号处理
Ailan_Anjuxi2 小时前
【附Python源码】使用minGPT训练自己的小型GPT语言模型
算法
QuZero2 小时前
StampedLock Mechanism
java·算法
云泽8082 小时前
二叉树高阶笔试算法题精讲(二):非递归遍历与序列构造全解析
c++·算法·面试