leetcode 22. 括号生成

题目如下

复制代码
因为题目中的括号只有一种组成括号的只有"("和")"故我们可以通过暴力搜索出答案("("和")"一样都只有两种状态放与不放且我们是从左到右生成的)。
那么,如何保证暴力搜索出的字符串是正确的括号对呢?
在回答这个问题之前我们来思考不正确的括号对是如何生成的吧
显然按照我们的生成方案当右括号多于左括号时括号对不正确。
所以我们通过数量限制来解决这些不正确的情况。

通过代码

cpp 复制代码
class Solution {
public:
void back(vector<string> &ans,int n,int left,int right,string s) {
    if(left + right == n * 2) {
        ans.push_back(s);
        return;
    }
    if(left < n) {
        back(ans,n,left + 1,right,s + "(");
    }
    if(right < left) {
        back(ans,n,left,right + 1,s + ")");
    }
}
vector<string> generateParenthesis(int n) {
        vector<string> ans;
        back(ans,n,0,0,"");
        return ans;
}

};
相关推荐
酷酷的崽79812 分钟前
如何在AVL树中高效插入并保持平衡:一步步掌握旋转与平衡因子 —— 旋转篇
c语言·数据结构·c++·算法
宇寒风暖17 分钟前
一文弄懂编辑距离算法(Levenshtein Distance)示例,通过动态规划计算两个字符串之间的最小编辑操作次数(插入、删除、替换)
开发语言·数据结构·笔记·学习·算法·动态规划
EPSDA21 分钟前
介绍HTTP协议基本结构与Linux中基本实现HTTPServer
linux·运维·开发语言·c++·网络协议·tcp/ip·http
一只码代码的章鱼24 分钟前
数据结构与算法-图论-二分图
算法·图论
每天被帅醒()26 分钟前
数据结构——栈
数据结构
孙同学_36 分钟前
【动态规划篇】746.使用最小花费爬楼梯
算法·动态规划
猿六凯44 分钟前
2023华东师范大学计算机复试上机真题
算法·华为od
小温不会码1 小时前
深入理解C/C++堆数据结构:从原理到实战
数据结构·c++·算法
_extraordinary_1 小时前
栈刷题+总结
算法·leetcode·
乘风上菜2 小时前
C++类与对象——拷贝构造与运算符重载
开发语言·c++