力扣热门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);
        }
    }
}

总结

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

相关推荐
hanbr1 小时前
每日一题day2(Leetcode 704二分查找)
数据结构·算法·leetcode
裕工实验室2 小时前
AMB陶瓷基板设计指南(工程师版)
算法·硬件工程·pcb工艺·材料工程
澈2072 小时前
深度优先遍历DFS:从入门到精通
算法·深度优先
计算机安禾2 小时前
【数据结构与算法】第45篇:跳跃表(Skip List)
c语言·数据结构·算法·list·排序算法·图论·visual studio
cmpxr_2 小时前
【算法】ECC验签名
单片机·算法
MRDONG12 小时前
深入理解 RAG(Retrieval-Augmented Generation):原理、工程体系与实践指南
人工智能·算法·语言模型·自然语言处理
别或许2 小时前
线代中为什么左乘一个列满秩矩阵,不改变矩阵的秩?
人工智能·算法·矩阵
wangbing11252 小时前
适配md5老算法
算法
Dev7z2 小时前
基于改进YOLO11算法的芯片微缺陷检测系统(UI界面+数据集+分析界面+处置建议+训练代码)
算法·芯片制造·yolo11