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 列表。
相关推荐
kkeeper~3 小时前
0基础C语言积跬步之深入理解指针(5下)
c语言·开发语言
一直不明飞行4 小时前
Java的equals(),hashCode()应该在什么时候重写
java·开发语言·jvm
REDcker4 小时前
有限状态机与状态模式详解 FSM建模Java状态模式与C++表驱动模板实践
java·c++·状态模式
盲敲代码的阿豪4 小时前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
你的保护色4 小时前
【无标题】
java·服务器·网络
basketball6164 小时前
C++ 构造函数完全指南:从入门到进阶
java·开发语言·c++
互联科技报4 小时前
2026超融合选型:Top5品牌与市场格局解读
开发语言·perl
weixin199701080165 小时前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python
淘矿人5 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
想唱rap5 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++