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;
    }
};
相关推荐
易只轻松熊1 分钟前
C++(23):容器类<vector>
开发语言·数据结构·c++
小学生的信奥之路8 分钟前
力扣1991:找到数组的中间位置(前缀和)
数据结构·算法·leetcode·前缀和·数组
এ᭄画画的北北13 分钟前
力扣-102.二叉树的层序遍历
数据结构·算法·leetcode
ccLianLian14 分钟前
数据结构·字典树
数据结构·算法
Lu Yao_26 分钟前
用golang实现二叉搜索树(BST)
开发语言·数据结构·golang
JeffersonZU2 小时前
【数据结构】2-3-1单链表的定义
数据结构·链表
JeffersonZU2 小时前
【数据结构】1-4算法的空间复杂度
c语言·数据结构·算法
L_cl2 小时前
【Python 算法零基础 4.排序 ① 选择排序】
数据结构·算法·排序算法
无聊的小坏坏3 小时前
【数据结构】二叉搜索树
数据结构
山北雨夜漫步3 小时前
机器学习 Day18 Support Vector Machine ——最优美的机器学习算法
人工智能·算法·机器学习