java练习(43)

ps:题目来自力扣

括号生成

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

复制代码
import java.util.ArrayList;
import java.util.List;

class Solution {
    public List<String> generateParenthesis(int n) {
        // 用于存储最终生成的有效括号组合的列表
        List<String> result = new ArrayList<>();
        // 调用回溯方法开始生成括号组合
        backtrack(result, new StringBuilder(), 0, 0, n);
        return result;
    }

    /**
     * 回溯方法,用于递归生成有效的括号组合
     * @param result 存储最终结果的列表
     * @param current 当前正在构建的括号组合
     * @param open 当前已使用的左括号数量
     * @param close 当前已使用的右括号数量
     * @param max 总共需要的括号对数
     */
    private void backtrack(List<String> result, StringBuilder current, int open, int close, int max) {
        // 当已使用的左括号和右括号数量都达到 max 时,说明已经生成了一个有效的括号组合
        if (current.length() == max * 2) {
            result.add(current.toString());
            return;
        }

        // 如果左括号的使用数量小于 max,继续添加左括号
        if (open < max) {
            current.append("(");
            // 递归调用,左括号使用数量加 1
            backtrack(result, current, open + 1, close, max);
            // 回溯操作,撤销上一步添加的左括号
            current.deleteCharAt(current.length() - 1);
        }

        // 如果右括号的使用数量小于左括号的使用数量,继续添加右括号
        if (close < open) {
            current.append(")");
            // 递归调用,右括号使用数量加 1
            backtrack(result, current, open, close + 1, max);
            // 回溯操作,撤销上一步添加的右括号
            current.deleteCharAt(current.length() - 1);
        }
    }
}

代码解释

本题要求生成 n 对有效的括号组合。我们可以使用回溯算法来解决这个问题。回溯算法的核心思想是通过递归的方式尝试所有可能的组合,并在满足特定条件时进行回溯。

具体步骤
  1. 初始化结果列表
    • 创建一个 ArrayList 类型的 result 列表,用于存储最终生成的有效括号组合。
  2. 调用回溯方法
    • 调用 backtrack 方法开始生成括号组合,传入结果列表、一个空的 StringBuilder 用于构建当前的括号组合、左括号使用数量初始值 0、右括号使用数量初始值 0 以及总共需要的括号对数 max
  3. 回溯方法 backtrack
    • 终止条件 :当 current 的长度等于 max * 2 时,说明已经生成了一个有效的括号组合,将其添加到结果列表中并返回。
    • 添加左括号 :如果左括号的使用数量小于 max,将左括号添加到 current 中,递归调用 backtrack 方法,左括号使用数量加 1,然后进行回溯操作,撤销上一步添加的左括号。
    • 添加右括号 :如果右括号的使用数量小于左括号的使用数量,将右括号添加到 current 中,递归调用 backtrack 方法,右括号使用数量加 1,然后进行回溯操作,撤销上一步添加的右括号。
  4. 返回结果
    • 当回溯过程结束后,返回存储所有有效括号组合的 result 列表。
相关推荐
caimouse2 小时前
reactos编码规范
c语言·开发语言
xieliyu.6 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
明夜之约6 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee6 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Jinkxs6 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
辣机小司6 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
CryptoPP7 小时前
快速对接东京证券交易所API数据:实战指南与代码示例
开发语言·人工智能·windows·python·信息可视化·区块链
ZC跨境爬虫7 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
fangdengfu1237 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
云烟成雨TD8 小时前
Spring AI 1.x 系列【51】可观测性技术选型
java·人工智能·spring