Go java 算法之括号生成示例详解

yizhihongxing

Go java 算法之括号生成示例详解

算法介绍

本算法是使用回溯算法来实现的,先在左边放置一个'(',再将')'放置在之前的'('后面。在任意时刻,使用的左括号数量都不应超过 n,也就是原本需要生成的数量。

代码实现

public List<String> generateParenthesis(int n) {

    List<String> result = new ArrayList<String>();

    if(n == 0) {
        return result;
    }

    String str = "";
    // 回溯
    backtrack(result, str, 0, 0, n);

    return result;
}

public void backtrack(
        List<String> result,
        String str,
        int open,
        int close,
        int n
){
    if(str.length() == 2*n) { // 生成完n个括号
        result.add(str);
        return;
    }

    // 左括号数量不能超过限制
    if(open<n) {
        backtrack(result, str + '(', open+1, close, n);
    }

    // 如果还有剩余的右括号未使用
    if(close<open) {
        backtrack(result, str + ')', open, close+1, n);
    }

}

示例说明

示例1:

生成括号对数为3个,运行结果如下:


List<String> list = generateParenthesis(3);
System.out.println(list);

输出结果:

["((()))", "(()())", "(())()", "()(())", "()()()"]

示例2:

生成括号对数为4个,运行结果如下:


List<String> list = generateParenthesis(4);
System.out.println(list);

输出结果:

["(((())))", "((()()))", "((())())", "((()))()", "(()(()))", "(()()())", "(()())()", "(())(())", "(())()()", "()((()))", "()(()())", "()(())()", "()()(())", "()()()()"]

以上就是本算法的详细攻略,希望能对您有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Go java 算法之括号生成示例详解 - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • SpringBoot应用快速部署到K8S的详细教程

    将Spring Boot应用快速部署到Kubernetes(K8S)是一项非常有用的技能,可以帮助开发人员更快地将应用程序部署到生产环境中。以下是Spring Boot应用快速部署到K8S的详细攻略: 1. 准备工作 在开始之前,需要完成以下准备工作: 安装Docker和Kubernetes 创建一个Docker镜像仓库 创建一个Kubernetes集群 2…

    Java 2023年5月14日
    00
  • 如何使用Java调试技术?

    下面我将为您详细讲解如何使用Java调试技术。 如何使用Java调试技术 什么是Java调试技术 Java调试技术是指利用各种工具和技术,用来检查程序运行状态和问题,并找到程序中的错误。 Java调试工具 目前常见的Java调试工具有以下几种: Eclipse IntelliJ IDEA NetBeans jdb jvisualvm jstack等 Java…

    Java 2023年5月11日
    00
  • java连接Oracle数据库的工具类

    下面是详细讲解 “Java连接Oracle数据库的工具类” 的完整攻略: 1. 准备工作 首先需要在本地或者服务器上安装Oracle数据库软件并成功启动,并在其上创建一个数据库实例,同时需要知道该实例的连接信息(IP地址、端口号、数据库名称、用户名、密码)。 然后需要在Java项目中引入Oracle JDBC驱动的jar包,例如ojdbc6.jar。 2. …

    Java 2023年5月20日
    00
  • 在JavaScript中调用Java类和接口的方法

    在JavaScript中调用Java类和接口的方法,一般需要通过Java的JavaScript引擎来实现。下面,我们将详细介绍调用Java类和接口方法的完整攻略。 步骤一:创建Java类和接口 为了在JavaScript中调用Java类和接口的方法,我们首先需要创建相应的Java类和接口。这里以Java类Calculator和Java接口Greeting为例…

    Java 2023年5月26日
    00
  • springboot多环境(dev、test、prod)配置详解

    在Spring Boot应用程序中,我们通常需要在不同的环境中配置不同的属性,例如数据库连接、日志级别等。以下是实现Spring Boot多环境配置的完整攻略: 创建配置文件 在Spring Boot应用程序中,我们可以使用不同的配置文件来配置不同的环境。以下是一个示例: application-dev.properties:开发环境配置文件。 applic…

    Java 2023年5月15日
    00
  • Java实现简单控制台版ATM系统

    Java实现简单控制台版ATM系统攻略 1. 需求分析 控制台版ATM系统主要需要实现以下功能: 用户登录、注册 存款、取款、查询余额 转账功能 2. 技术选型 本篇攻略使用Java语言实现控制台版ATM系统,使用了Java IO、集合等基础知识进行编写。在框架上,本篇攻略并未用到任何框架。 3. 代码实现 代码实现主要分为以下几个部分: 3.1 用户登录、…

    Java 2023年5月18日
    00
  • 什么是死锁?

    以下是关于死锁的完整使用攻略: 什么是死锁? 死锁是指两个或多个线程在执行过程中,因互相等待对方释放资源而陷入的一种僵局。在死锁状态下,每个线程都在等待其他线程释放资源,从而导致线程都无法继续执行下去。锁是多线程编程中的一种常见问题,如果不加以处理,可能会导致程序崩溃。 死锁的原因 死锁的原因主要有两个方面: 竞争资源:当多个线程竞争同资源时可能会导致死锁。…

    Java 2023年5月12日
    00
  • Spring Boot集成Quartz注入Spring管理的类的方法

    下面详细讲解如何使用Spring Boot集成Quartz并注入Spring管理的类。 准备工作 首先,我们需要引入相关依赖。在 pom.xml 中加入以下依赖: <!– Quartz –> <dependency> <groupId>org.quartz-scheduler</groupId> <a…

    Java 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部