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

总结

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

相关推荐
kkeeper~2 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs6664 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964134 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚4 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本5 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov6 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫6 小时前
特征工程处理
人工智能·算法·机器学习
z落落7 小时前
C#参数区别
java·算法·c#
c238567 小时前
vector(下)
数据结构·算法
z落落7 小时前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法