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;
    }
};
相关推荐
2501_9412362121 分钟前
C++与Node.js集成
开发语言·c++·算法
晨非辰23 分钟前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
云边有个稻草人3 小时前
部分移动(Partial Move)的使用场景:Rust 所有权拆分的精细化实践
开发语言·算法·rust
泡沫冰@5 小时前
数据结构(20)
数据结构
松涛和鸣5 小时前
11.C 语言学习:递归、宏定义、预处理、汉诺塔、Fibonacci 等
linux·c语言·开发语言·学习·算法·排序算法
2501_941111246 小时前
C++与自动驾驶系统
开发语言·c++·算法
2501_941111697 小时前
C++中的枚举类高级用法
开发语言·c++·算法
jz_ddk7 小时前
[算法] 算法PK:LMS与RLS的对比研究
人工智能·神经网络·算法·信号处理·lms·rls·自适应滤波
Miraitowa_cheems7 小时前
LeetCode算法日记 - Day 106: 两个字符串的最小ASCII删除和
java·数据结构·算法·leetcode·深度优先
旭编7 小时前
小红的好矩形
c++·算法