leetcode-括号生成

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

示例 1:

输入:n = 3

输出:"((()))","(()())","(())()","()(())","()()()"

示例 2:

输入:n = 1

输出:"()"

提示:

1 <= n <= 8

思路 :对于当前位置,有两种情况。选左括号或者选右括号。当左括号数量大于右括号数量时,后面无论怎么选择都无法再组成成对的括号。直接返回。
代码

c 复制代码
class Solution {
    public List<String> generateParenthesis(int n) {
        List<String> res = new ArrayList<>();
        dfs(n,n,"",res);
        return res;
    }
    public void dfs(int left,int right,String temp, List<String> res){
        if(left<0||right<0){
            return;
        }
        // 后续无法组成成对括号
        if(left>right){
            return;
        }
        if(left==0&&right==0){
            res.add(temp);
            return;
        }
        // 当前位置选左括号
        dfs(left-1,right,temp+"(",res);
        // 当前位置选右括号
        dfs(left,right-1,temp+")",res);
    }
}
相关推荐
科研online10 小时前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy10 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯10 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b11 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术11 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi811 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
hujinyuan2016011 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
froyoisle12 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学
珊瑚里的鱼12 小时前
【动态规划】打家劫舍Ⅱ
算法·动态规划
chao18984412 小时前
SGM(Semi-Global Matching)立体匹配算法 — C++ 实现
开发语言·c++·算法