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 列表。
相关推荐
寻星探路2 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
lly2024063 小时前
Bootstrap 警告框
开发语言
2601_949146534 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
曹牧4 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
KYGALYX4 小时前
服务异步通信
开发语言·后端·微服务·ruby
zmzb01034 小时前
C++课后习题训练记录Day98
开发语言·c++
爬山算法5 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7255 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎5 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄5 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea