leetcode 22. 括号生成

2023.9.24

看到组合两个字,想到了回溯。 大致思路是将所有可能的组合列出来,通过中止条件筛选掉无效的括号。 第一个中止条件:如果右括号数量大于左括号,那括号肯定无效。 第二个中止条件:当左右括号数量相等,并且都等于n时,说明这个括号符合条件,加入ans数组中,再return继续寻找。 图示和代码如下:

cpp 复制代码
class Solution {
private:
    //全局变量
    vector<string> ans;
    string path;
public:
    void backtrating(int n,int left,int right) //left和right是左右括号的数量
    {
        //中止条件
        if(right > left) return;
        if(left == right && left == n)
        {
            ans.push_back(path);
            return;
        }
        //优先加左括号
        if(left < n)
        {
            path += '(';
            backtrating(n,left+1,right);
            path.pop_back();
        }
        //加右括号
        if(left > right)
        {
            path += ')';
            backtrating(n,left,right+1);
            path.pop_back();
        }
    }
    vector<string> generateParenthesis(int n) {
        backtrating(n,0,0);
        return ans;
    }
};
相关推荐
小袁顶风作案几秒前
leetcode力扣——135.分发糖果
算法·leetcode·职场和发展
于齐龙3 分钟前
2025年12月24日 - 数据结构
数据结构
橘颂TA11 分钟前
【Linux】从 “抢资源” 到 “优雅控场”:Linux 互斥锁的原理与 C++ RAII 封装实战(Ⅰ)
linux·运维·服务器·c++·算法
YGGP26 分钟前
【Golang】LeetCode 19. 删除链表的倒数第 N 个节点
算法·leetcode·链表
池塘的蜗牛33 分钟前
mmse-based-OFDM-signal-processing(2)
算法
平生不喜凡桃李40 分钟前
Leetcode-240 :搜索二维矩阵
leetcode·矩阵·深度优先
Kris_LinSD42 分钟前
算法小实验——分治算法快速排序问题实验(含报告)
c语言·算法
Super小白&43 分钟前
十大经典排序算法详解(附C语言实现+复杂度分析)
c语言·算法·排序算法
Eloudy43 分钟前
Birkhoff 多胞形,双随机矩阵的几何世界
算法