Leetcode:括号生成

题目链接:22. 括号生成 - 力扣(LeetCode)

题目分析

1、括号的类型只有()一种,没有{}或者[]

2、括号可以进行多层嵌套

3、有效的括号组合需要满足以下两个条件***(任意一个子串)***

  • 总体上,左括号数量 == 右括号数量
  • 从左向右开始数一个子串时,在任意时刻,左括号的数量 >= 右括号数量

4、当我们开始进行生成时,会出现下图所示的过程:

  • 当left大于等于n时就不能再添加左括号
  • 当right大于等于left时也不能添加左括号
  • 当right==n时开始回退***(因为先添加的肯定是左括号,所以后添加的右括号都等于n了,那么左括号应该也满足了)***

普通版本(回溯)

cpp 复制代码
class Solution {
    int left,right,m;
    string path;//每一条路径上的最终结果
    vector<string> res;//最终结果
public:
    vector<string> generateParenthesis(int n) {
       m = n;
       dfs();//当dfs函数走完后所有的括号就完成了括号的组成
       return res;
    }

    void dfs()
    {
        if(right == m)
        {
            res.push_back(path);//将当前组合完成的子串尾插给最终结果
            return;
        }

        if(left < m)//用递归添加左括号
        {
            path.push_back('(');
            ++left;
            dfs();
            path.pop_back();
            --left;
        }

        if(right < left)//添加右括号
        {
            path.push_back(')');
            ++right;
            dfs();
            path.pop_back();
            --right;
        }
    }
};

优化版本(待补充)

~over~

相关推荐
灵典3361 分钟前
数据结构入门-二叉树的层序遍历
数据结构·算法
范纹杉想快点毕业5 分钟前
以项目的方式学QT开发(三)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·开发语言·c++·qt·mysql·算法·命令模式
补三补四7 分钟前
随机森林(Random Forest)
人工智能·科技·算法·随机森林·机器学习
轮到我狗叫了10 分钟前
力扣.1471数组的k个最强值,力扣.1471数组的k个最强值力扣1576.替换所有的问号力扣1419.数青蛙编辑力扣300.最长递增子序列
java·数据结构·算法
赵青临的辉30 分钟前
常见机器学习算法简介:回归、分类与聚类
算法·机器学习·回归
程序员莫小特31 分钟前
【GESP真题解析】第 20 集 GESP 二级 2025 年 3 月编程题 1:等差矩阵
c语言·数据结构·c++·算法·青少年编程·矩阵
weixin_3870021537 分钟前
使用GmSSL v3.1.1实现SM2证书认证
算法·安全·区块链·密码学·ssl
八股文领域大手子1 小时前
磁盘I/O瓶颈排查:面试通关“三部曲”心法
面试·职场和发展
啥都鼓捣的小yao1 小时前
课程11. 计算机视觉、自编码器和生成对抗网络 (GAN)
人工智能·python·深度学习·神经网络·算法·生成对抗网络·计算机视觉
ROCKY_8171 小时前
数据结构(九)——排序
数据结构·算法·排序算法