蓝桥杯——分组比赛(2017JavaB组第3题)
分组比赛(17JavaB3)
9名运动员参加比赛,需要分3组进行预赛。
有哪些分组的方案呢?
标记运动员为 A,B,C,... I
下面的程序列出了所有的分组方法:
ABC DEF GHI
ABC DEG FHI
ABC DEH FGI
ABC DEI FGH
..... (以下省略,总共560行)。
分析:代码填空题,改成编码题
先排三个,再排三个,最后排三个
(1)先分有A的一组:
| ABC | ||||||
|---|---|---|---|---|---|---|
| ABD | ACD | |||||
| ABE | ACE | ADE | ||||
| ABF | ACF | ADF | AEF | |||
| ABG | ACG | ADG | AEG | AFG | ||
| ABH | ACH | ADH | AEH | AFH | AGH | |
| ABI | ACI | ADI | AEI | AFI | AGI | AHI |
第一位:全A
第二位:B—H,即第一位后——H
第三位:第二位后——I
public class 分组比赛1 {
public static void main(String[] args) {
int LEN = 9;
for (int _n2 = 1; _n2 < LEN; _n2++) {
for (int _n3 = _n2 + 1; _n3 < LEN; _n3++) {
String s = "A" + (char) (_n2 + 'A') + (char) (_n3 + 'A');
System.out.println(s);
}
}
}
}
(2)再分第二组
(3)最后剩下的三个为一组
详细设计
定义数组_flag[9](已分组=1,未分组=0)
A必排第一个,无条件_flag[0]=1
排第二个(n2):for(1 ~ length-1)
n2已分组(_flag[n2] = 1)
排第三个(n3):for(n2+1 ~ length-1)
n3已分组(_flag[n3] = 1)
前三个分组完成!
String s1 = 拼出前三内容
call再分三个(s1,_flag数组)
n3分组完成(_flag[n3] = 0)
n2分组完成(_flag[n2] = 0)
void 再分三个(s1,_flag数组){
排第四个(i):for(1 ~ length-1)
_flag[i]已经分组?continue:_flag=1;
排第五个(j):for(i+1 ~ length-1)
_flag[j]已经分组?continue:_flag=1;
排第六个(k):for(j+1 ~ length-1)
_flag[k]已经分组?continue:_flag=1;
中间三个分组完成!
分最后三个:
for(1 ~ length-1){
_flag=0的全部是
}
本次分组完成!
拼出s2,s3
System.out.println(s1+s2+s3);
k分组完成 (_flag = 0)
j分组完成 (_flag = 0)
i分组完成 (_flag = 0)
}
参考代码
package bb;
public class 分组比赛16JB3 {
public static String m分最后三个(int[] a) {
String s = "";
// 从0开始扫描(从1开始也行,反正A必是已被分组)
// 没分组的全放进来
for (int i = 0; i < a.length; i++) {
if (a[i] == 0) {
s += (char) (i + 'A');
}
}
return s;
}
private static int num = 1;
public static void m再分三个(String s, int[] a) {
// 排4,5,6三人
// 第4人从0开始扫描(从1开始也行,反正A必是已被分组)
for (int i = 1; i < a.length; i++) {
if (a[i] == 1) {// 此人未分组则分之,分了组则跳过
continue;
} else {
a[i] = 1;
}
// 第5人从i+1开始扫描
for (int j = i + 1; j < a.length; j++) {
if (a[j] == 1) {
continue;
} else {
a[j] = 1;
}
// 第6人从j+1开始扫描
for (int k = j + 1; k < a.length; k++) {
if (a[k] == 1) {
continue;
} else {
a[k] = 1;
}
// 填空
System.out.print(num++);
System.out.print(" ");
// 天空位置在此:
System.out.println(s + " " + (char) ('A' + i) + (char) ('A' + j)
+ (char) ('A' + k) + " " + m分最后三个(a)); // 填空位置
a[k] = 0;// 这是一一列举,这次输出了,不要占用,让出分组位置
}
a[j] = 0;
}
a[i] = 0;
}
}
public static void main(String[] args) {
// 数组_flag,原题是数组a,表意性不强,用于标识每个运动员是否被分组
// 已分组=1
// 未分组=0
int[] _flag = new int[9];
_flag[0] = 1;// 分第一个运动员A(下标为0)
for (int _n2 = 1; _n2 < _flag.length; _n2++) {
_flag[_n2] = 1;// 分这个
for (int _n3 = _n2 + 1; _n3 < _flag.length; _n3++) {
_flag[_n3] = 1;// 分这个
String s = "A" + (char) (_n2 + 'A') + (char) (_n3 + 'A');
m再分三个(s, _flag);
_flag[_n3] = 0;
}
_flag[_n2] = 0;
}
}
}
蓝桥杯——分组比赛(2017JavaB组第3题)的更多相关文章
- 蓝桥杯——复数幂 (2018JavaAB组第3题)
18年Java蓝桥杯A组第3题和B组是一样的. 第三题往往比较难. 复数幂 (18JavaAB3) (A.B两卷第三题一样) 设i为虚数单位.对于任意正整数n,(2+3i)^n 的实部和虚部都是整数. ...
- 蓝桥杯——快速排序(2018JavaB组第5题9分)
快速排序(18JavaB5,9') 以下代码可以从数组a[]中找出第k小的元素. 它使用了类似快速排序中的分治算法,期望时间复杂度是O(N)的. 请仔细阅读分析源码,填写划线部分缺失的内容. impo ...
- 第七届蓝桥杯省赛javaB组 第七题剪邮票
剪邮票 如[图1.jpg], 有12张连在一起的12生肖的邮票.现在你要从中剪下5张来,要求必须是连着的.(仅仅连接一个角不算相连)比如,[图2.jpg],[图3.jpg]中,粉红色所示部分就是合格的 ...
- 2015年蓝桥杯省赛B组第3题--三羊献瑞
三羊献瑞 观察下面的加法算式: 祥 瑞 生 辉 + 三 羊 献 瑞 ------------------- 三 羊 生 瑞 气 (如果有对齐问题,可以参看[图1.jpg]) 其中,相同的 ...
- 蓝桥杯——螺旋折线(2018JavaB组第7题19分)
螺旋折线(18JB-7-19') 如图p1.pgn所示的螺旋折线经过平面上所有整点恰好一次. 对于整点(X, Y),我们定义它到原点的距离dis(X, Y)是从原点到(X, Y)的螺旋折线段的长度. ...
- 蓝桥杯——字母阵列(2018JavaC组第3题)
字母阵列(18JavaC3) 标题:字母阵列 仔细寻找,会发现:在下面的8x8的方阵中,隐藏着字母序列:"LANQIAO". SLANQIAO ZOEXCCGB MOAYWKHI ...
- 第七届蓝桥杯省赛JavaB组——第十题压缩变换
题目: 压缩变换小明最近在研究压缩算法.他知道,压缩的时候如果能够使得数值很小,就能通过熵编码得到较高的压缩比.然而,要使数值很小是一个挑战.最近,小明需要压缩一些正整数的序列,这些序列的特点是,后面 ...
- 52-2018 蓝桥杯省赛 B 组模拟赛(一)java
最近蒜头君喜欢上了U型数字,所谓U型数字,就是这个数字的每一位先严格单调递减,后严格单调递增.比如 212212 就是一个U型数字,但是 333333, 9898, 567567, 313133131 ...
- 算法笔记_216:第六届蓝桥杯软件类校赛部分真题(Java语言C组)
目录 1 题目一 2 题目二 3 题目三 4 题目四 5 题目五 前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 题目一 二项式的系数规律,我国数学家很早就发现了. 如[图1.png],我国南宋数学 ...
随机推荐
- 【Golang】vscode 设置 go 开发环境
步骤 1. 始 Golang 语言开发选择一款合适的编辑器,能加速你敲字的灵感,这里推荐微软的 Visual Studio Code,简称 vscode. 2. 安装 go 插件 首先需要安装 go ...
- 关于Java引用,你必须知道这些
引用 Java 虚拟机接管了所有的内存分配与回收工作,极大地减少了程序员的工作量和错误率.GC 在回收内存时,通常采用被称为可达性分析的算法判断一个对象是否可以回收.而在可达性分析中,对象的引用有着决 ...
- Java学习的第三十二天
1. 2.综合例题没太看懂 3.明天复习第十二章
- sharding-jdbc 分库分表的 4种分片策略,还蛮简单的
上文<快速入门分库分表中间件 Sharding-JDBC (必修课)>中介绍了 sharding-jdbc 的基础概念,还搭建了一个简单的数据分片案例,但实际开发场景中要远比这复杂的多,我 ...
- 万亿级KV存储架构与实践
一.KV 存储发展历程 我们第一代的分布式 KV 存储如下图左侧的架构所示,相信很多公司都经历过这个阶段.在客户端内做一致性哈希,在后端部署很多的 Memcached 实例,这样就实现了最基本的 KV ...
- xshell断线解决办法
困扰了好几个月了,网上更改ssh配置文件.固定ip都不好使,终于找到xshell掉线的解决办法了 哈哈!!! 设备管理器-->网络适配器-->对应网络连接虚拟机方式,本机虚拟机桥接如图 右 ...
- ubunutu16.04 更改普通用户权限注销后只有guest身份 没有用户身份
第一次踩进百度经验的坑..... 之前对百度经验百信不疑,现在怀疑人生.. 网上搜了很多,也变得小心翼翼,最后姑且相信,但还是有点出入,以下是我的实践: (1)重启ubuntu系统,长按shift进入 ...
- leetcode132:4sum
题目描述 给出一个有n个元素的数组S,S中是否有元素a,b,c和d满足a+b+c+d=目标值?找出数组S中所有满足条件的四元组. 注意: 四元组(a.b.c.d)中的元素必须按非降序排列.(即a≤b≤ ...
- Python正则表达式-换行的匹配
找到了之前参考的博文,用来记录一下https://www.cnblogs.com/baxianhua/p/8572805.html 平常 点 (.)去匹配任意字符的时候,是不能匹配换行符的 匹配换行: ...
- 解决无法访问 Github
可以正常使用Google,但无法打开Github. 查阅了一些资料,发现需要在hosts文件中添加映射. 在hosts文件中加入两行 140.82.113.4 github.com 140.82.11 ...