LeetCode:22括号生成

java 复制代码
class Solution {
    List<String> res = new ArrayList<>();

    public List<String> generateParenthesis(int n) {
        backtrack(new StringBuilder(), 0, 0, n);
        return res;    
    }

    //left代表已经用掉的左括号的数量,right代表用掉的右括号的数量
    private void backtrack(StringBuilder path, int left, int right, int n){
        if(path.length() == n * 2){
            res.add(path.toString());
            return;
        }
        //加左括号
        if(left < n){
            path.append("(");
            backtrack(path, left + 1, right, n);
            path.deleteCharAt(path.length() - 1);
        }
        //加右括号
        if(right < left){
            path.append(")");
            backtrack(path, left, right + 1, n);
            path.deleteCharAt(path.length() - 1);
        }
    }
}

必须在right小于left的时候才能加")",不然提前加上会造成结果不合法

相关推荐
cfm_29141 小时前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
郝学胜_神的一滴1 小时前
干货版《算法导论》09:让哈希表稳如泰山的终极解法
数据结构·算法
CC数学建模2 小时前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题C题:创业社区规划与资源配置优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
徐小夕2 小时前
我们放弃了单Agent方案:HiCAD 3.0 用 Harness 做多Agent编排,把3D建模的准确率提升了30%
前端·算法·github
洛水水2 小时前
【力扣100题】88.多数元素
数据结构·算法·leetcode
Shan12052 小时前
无向图的Hierholzer算法流程(一)
算法
一切皆是因缘际会2 小时前
频域特征解构底层机理与双域融合鉴伪算法优化
人工智能·算法·ai·架构
Smilecoc2 小时前
决策树(三):剪枝
算法·决策树·剪枝
bIo7lyA8v2 小时前
算法性能建模的数值方法与误差分析的技术8
算法