Leetcode22 —— 括号生成

目录

题目:

题解:

C++代码:

代码细节:

题目:

题解:

  • 核心方法:回溯 + 剪枝,通过深度优先遍历构建括号字符串,同时用规则过滤无效路径;

  • 路径与约束

    • 路径:用 current 记录当前构建的括号串;

    • 剪枝规则:左括号数不超 n,右括号数不超左括号数(保证有效前缀);

  • 递归逻辑

    • 终止条件:字符串长度为 2n,将其加入结果集;

    • 递归选择:先尝试加左括号(满足约束时),递归探索后撤销选择;再尝试加右括号(满足约束时),递归探索后撤销选择;

  • 主函数:初始化结果集和临时字符串,启动回溯,最终返回所有有效组合。

C++代码:

复制代码
class Solution {

    void backtrack(vector<string>& result , string& c , int open, int close ,int n){
        if(c.size() == 2*n){
            result.push_back(c);
            return;
        }
        // 左括号未使用完
        if(open < n){
            c.push_back('(');
            backtrack(result, c, open+1,close,n);
            c.pop_back();
        }
        // 满足右括号小于左括号
        if(close < open ){
            c.push_back(')');
            backtrack(result, c, open,close+1,n);
            c.pop_back();
        }

    }
public:
    vector<string> generateParenthesis(int n) {
        //调用我们定义的函数
        vector<string> result;
        string cur;
        backtrack(result,cur,0,0,n);
        return result;
    }
};

代码细节:

这里的 ans和cur需要用引用类型才能被实际修改

vector<string>& ans 引用类型的字符串数组,存储所有有效括号字符串 string& cur 引用类型的字符串

相关推荐
小光学长11 分钟前
基于ssm的膳食健康管理系统e6whl4q7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·开发语言·数据库·学习·ssm
java1234_小锋12 分钟前
Java高频面试题:Redis到底支不支持事务啊?
java·redis·面试
无心水15 分钟前
【常见错误】2、Java并发编程避坑指南:从加锁失效到死锁,10个案例教你正确使用锁
java·开发语言·python
我爱学习好爱好爱16 分钟前
Kubernetes 1.29集群上部署Java网站项目
java·容器·kubernetes
青衫码上行16 分钟前
【项目开发日记 | Java架构】第一天
java·开发语言·spring cloud
至为芯20 分钟前
IP2075_34S至为芯支持C口快充的30W功率AC/DC芯片
c语言·开发语言
DJ斯特拉28 分钟前
自定义jar包导入maven&&注册第三方bean
java·maven·jar
AI_567830 分钟前
基于智优达平台的Python教学实践:从环境搭建到自动评测
开发语言·前端·人工智能·后端·python
j_xxx404_35 分钟前
力扣困难算法精解:串联所有单词的子串与最小覆盖子串
java·开发语言·c++·算法·leetcode·哈希算法
嘉琪00135 分钟前
前端数组核心方法(高级视角 + 场景 + 精简)——————2026 0309
开发语言·前端·javascript