"比赛安排"问题详细解答(java实现)

一.问题

在这里插入图片描述

二.要求

在这里插入图片描述

三.解答

import java.util.Arrays;
import java.util.Scanner;

public class test {
	public static void main(String[] args) {
		System.out.println("请输入组数:");
		Scanner sysin= new Scanner(System.in);
		int n = sysin.nextInt();
		int sum = (int)Math.pow(2, n);  // 表示比赛总队伍
		int group =(int)Math.pow(2, n-1); //表示一天比赛的组数
		int day = sum-1;  // 表示比赛天数
		boolean groupOver[][] = new boolean[sum+1][sum+1];  // 记录哪两支队伍已经参加了比赛
		boolean vis[] = new boolean[sum+1];  // 记录一天里该队伍是否已经有了安排
		for(int i=1;i<=day;i++) {
			Arrays.fill(vis,false);  // 初始化数组
			int count = 0;  // 计组数,每天初始化一次
			System.out.print("<"+i+">");
			for(int j=1;j<=sum;j++) {
				if(vis[j]) {
					continue; // 第j支队伍如果已经作为了前面队伍的选手则跳过
				}
				vis[j]=true;  // 为第j支队伍安排对手,标记其已被遍历过
				for(int k=j;k<=sum;k++) {
					if(!vis[k]&&!groupOver[j][k]) {  
						//如果从小到大找到队伍k,且j队伍与k队伍没有比赛过而且k队伍在1当天还没有安排则安排j与k比赛
						groupOver[j][k]=true; // 标记j,k两支队伍已经比过
						vis[k]=true;  // 标记k被遍历过
						count++;  // 表示比赛组数
						System.out.printf("%d-%d",j,k);  // 输出比赛的两队
						if(count!=group) {
							System.out.print(",");  //如果是这一天的最后一组就不输出逗号
						}
						break;
					}
				}
			}
			System.out.println();
		}
		sysin.close();
	}
}

四.运行结果

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杜柠函

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值