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

总结

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

相关推荐
Jack203 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树4 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE21220 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21221 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法