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;
    }
};
相关推荐
吃着火锅x唱着歌4 分钟前
LeetCode 面试题 16.24.数对和
算法·leetcode·职场和发展
不会编程的小寒4 分钟前
数据结构 2.0
数据结构·算法
专注VB编程开发20年9 分钟前
图片转矢量图(提取轮廓线条)Potrace:一个基于多边形的位图轮廓矢量化算法(translation)
算法·图片转矢量
while(1){yan}10 分钟前
MYSQL索引的底层数据结构
数据结构·数据库·mysql
Dream it possible!32 分钟前
LeetCode 面试经典 150_二叉树层次遍历_二叉树的层平均值(82_637_C++_简单)
c++·leetcode·面试·二叉树
小羊失眠啦.33 分钟前
Rust核心库(core)深度解析:无依赖基石的设计与实践
数据库·算法·rust
Wenhao.35 分钟前
LeetCode Hot100 每日温度
数据结构·算法·leetcode·golang
吃着火锅x唱着歌37 分钟前
LeetCode 1679.K和数对的最大数目
算法·leetcode·职场和发展
im_AMBER38 分钟前
Leetcode 57
笔记·学习·算法·leetcode
im_AMBER39 分钟前
Leetcode 58 | 附:滑动窗口题单
笔记·学习·算法·leetcode