回溯-dfs-力扣,括号生成

数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的括号组合。

示例 1:

复制代码
输入:n = 3
输出:["((()))","(()())","(())()","()(())","()()()"]

示例 2:

复制代码
输入:n = 1
输出:["()"]

提示:

  • 1 <= n <= 8
cpp 复制代码
class Solution {
public:
     vector<string> generateParenthesis(int n) {
             vector<string> res;     
                getS("",n,n,res);
                  return res ;
    }
 void  getS(string s,int left,int right, vector<string>& res)
          {
               if(!left&&!right){
                res.push_back(s);
                  return;
               }

               if(left){
                 
                  getS(s+"(",left-1,right,res);
               }
               if(right&&right>left)   //剩下的越多,用到的越少
                {
                   
                     getS(s+")",left,right-1,res);
                }
          }

};
相关推荐
BLSxiaopanlaile14 分钟前
关于子集和问题的几种解法
数据结构·算法·剪枝·回溯·分解
狐5723 分钟前
2026-01-17-LeetCode刷题笔记-3047-求交集区域内的最大正方形面积
笔记·算法·leetcode
Yzzz-F26 分钟前
P3509 [POI 2010] ZAB-Frog[单调队列+倍增快速幂思想]
算法
代码无bug抓狂人29 分钟前
C语言之5位黑洞数
c语言·算法
CodeByV33 分钟前
【算法题】BFS:FloodFill
算法
long31637 分钟前
弗洛伊德·沃肖算法 Floyd Warshall Algorithm
java·后端·算法·spring·springboot·图论
有一个好名字38 分钟前
力扣-咒语和药水的成功对数
java·算法·leetcode
Loo国昌43 分钟前
【LangChain1.0】第一篇:基础认知
后端·python·算法·语言模型·prompt
H Corey1 小时前
Java--面向对象之继承与多态
java·开发语言·windows·学习·算法·intellij-idea
永远都不秃头的程序员(互关)1 小时前
【K-Means深度探索(三)】告别“初始陷阱”:K-Means++优化质心初始化全解析!
算法·机器学习·kmeans