蓝桥杯历年真题 省赛 Java b组 2016年第七届

2024-03-14 08:12

本文主要是介绍蓝桥杯历年真题 省赛 Java b组 2016年第七届,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目

分小组

9名运动员参加比赛,需要分3组进行预赛。
有哪些分组的方案呢?

我们标记运动员为 A,B,C,... I
下面的程序列出了所有的分组方法。

该程序的正常输出为:
ABC DEF GHI
ABC DEG FHI
ABC DEH FGI
ABC DEI FGH
ABC DFG EHI
ABC DFH EGI
ABC DFI EGH
ABC DGH EFI
ABC DGI EFH
ABC DHI EFG
ABC EFG DHI
ABC EFH DGI
ABC EFI DGH
ABC EGH DFI
ABC EGI DFH
ABC EHI DFG
ABC FGH DEI
ABC FGI DEH
ABC FHI DEG
ABC GHI DEF
ABD CEF GHI
ABD CEG FHI
ABD CEH FGI
ABD CEI FGH
ABD CFG EHI
ABD CFH EGI
ABD CFI EGH
ABD CGH EFI
ABD CGI EFH
ABD CHI EFG
ABD EFG CHI
..... (以下省略,总共560行)。

二、代码


package Lan2016;public class D分小组 {public static String remain(int[] a)//用于把最后三个字母找到{String s = "";//令s为空串for(int i=0; i<a.length; i++){if(a[i] == 0) s += (char)(i+'A');//如果当前位置的值是0的话,我们找出最后的三个字母}return s;}public static void f(String s, int[] a)//传进去的值是 前三个字母,和数组//用于找中间的三位字母(三层循环),并把最后三位的字母以调用remain函数而找到{for(int i=0; i<a.length; i++){if(a[i]==1) continue;//当当前位置等于1的话,我们跳出当前的循环,进入下一次的循环,直到找到不是1的数组下标a[i] = 1;//把当前不是1的数组赋值为1for(int j=i+1; j<a.length; j++){if(a[j]==1) continue;//是1的话,计入下一个循环a[j]=1;//不是1的话,赋值为1for(int k=j+1; k<a.length; k++){if(a[k]==1) continue;a[k]=1;System.out.println(s + " " +(char)('A' + i) + (char)('A' + j) + (char)('A' + k) + " " +remain(a));//打印s(前三个字母)和中间三个字母,和最后三个字母,中间以空格隔开
/*System.out.println("__________________________________");  //填空位置
*/a[k]=0;//找到一种组合之后,把数组当前的位置赋值为0,便于下一次遍历字母的组合}a[j]=0;//找到一种组合之后,把数组当前的位置赋值为0,便于下一次遍历字母的组合}a[i] = 0;//找到一种组合之后,把数组当前的位置赋值为0,便于下一次遍历字母的组合}}public static void main(String[] args){int[] a = new int[9]; //数组,有9个数a[0] = 1;//第一个元素是1,表示选择A字母for(int b=1; b<a.length; b++){//两层for循环来找出A后面的俩字母a[b] = 1;//设置为1 表示这个位置的字母已经被选择过for(int c=b+1; c<a.length; c++){//c=b+1,是因为当b选择当前的字母,c会从下一个字母开始遍历a[c] = 1;//c位置赋1,表示此位置的字母已经被选择String s = "A" + (char)(b+'A') + (char)(c+'A');//组成字符串,以A**的形式,b+'A',表示A以后的字母所对应的数,在转化成字符类型f(s,a);//调用f方法a[c] = 0;//将当前的位置又赋值为0,方便下一次循环找下一个字母}a[b] = 0;//将当前的位置又赋值为0,方便下一次循环找下一个字母}}
}

 

三、反思 

        读懂代码是关键,

数组会自动赋初值0,

(char)(b+'A')将b转化成对应的ASCII字符,

所要填空的位置正式最后所要输出的答案区域

这篇关于蓝桥杯历年真题 省赛 Java b组 2016年第七届的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807763

相关文章

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.