【分治算法】【Python实现】循环赛日程表

news2025/1/13 10:03:45

文章目录

    • @[toc]
      • 问题描述
      • 分治算法
        • 示例
        • `Python`实现
      • 无运动员数量约束循环赛日程表算法
        • 示例
        • `Python`实现

因上努力

个人主页:丷从心·

系列专栏:分治算法

学习指南:Python学习指南

果上随缘


问题描述

  • 设有 n = 2 k n = 2^{k} n=2k个运动员要进行网球循环赛,设计一个满足以下要求的比赛日程表
    • 每个选手必须与其他 n − 1 n - 1 n1个选手各赛一次
    • 每个选手一天只能赛一次
    • 循环赛一共进行 n − 1 n - 1 n1

分治算法

  • n n n个选手的比赛日程表可以通过 n / 2 n / 2 n/2个选手的比赛日程表决定,递归调用,直到只剩下两个选手,比赛日程表的制定就变得简单了
示例
  • 8 8 8个选手的比赛日程表
  • 先制定 2 2 2个选手的比赛日程表,如下图所示

1

  • 有了最基本情况后就可以逐层返回,得到 4 4 4个选手的比赛日程表,如下图所示

2

  • 最后得到 8 8 8个选手的比赛日程表,如下图所示

3

  • 其中第 1 1 1列表示 8 8 8个选手,第 i ( 2 ≤ i ≤ 8 ) i (2 \leq i \leq 8) i(2i8)列表示第 i − 1 i - 1 i1天每个选手的对手
Python实现
def generate_schedule(k):
    # 选手数为 2 的 k 次方
    n = 2 ** k

    # 创建一个大小为 (n + 1) * (n + 1) 的二维列表, 用于存储日程表
    schedule = [[0] * (n + 1) for _ in range(n + 1)]

    # 初始化第一行, 将 1 到 n 依次填入日程表中
    for i in range(1, n + 1):
        schedule[1][i] = i

    m = 1

    # 分治 k 次
    for s in range(1, k + 1):
        # 每次循环后, 日程表的大小减半
        n //= 2

        # 对每个子表进行循环
        for t in range(1, n + 1):
            for i in range(m + 1, 2 * m + 1):  # 子表的行范围
                for j in range(m + 1, 2 * m + 1):  # 子表的列范围
                    # 将左上部分的值复制到右下部分
                    schedule[i][j + (t - 1) * m * 2] = schedule[i - m][j + (t - 1) * m * 2 - m]
                    # 将右上部分的值复制到左下部分
                    schedule[i][j + (t - 1) * m * 2 - m] = schedule[i - m][j + (t - 1) * m * 2]

        # 每次循环后, 子表的大小翻倍
        m *= 2

    return schedule


k = 3

schedule = generate_schedule(k)

for item in schedule:
    print(item)
[0, 0, 0, 0, 0, 0, 0, 0, 0]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
[0, 2, 1, 4, 3, 6, 5, 8, 7]
[0, 3, 4, 1, 2, 7, 8, 5, 6]
[0, 4, 3, 2, 1, 8, 7, 6, 5]
[0, 5, 6, 7, 8, 1, 2, 3, 4]
[0, 6, 5, 8, 7, 2, 1, 4, 3]
[0, 7, 8, 5, 6, 3, 4, 1, 2]
[0, 8, 7, 6, 5, 4, 3, 2, 1]

无运动员数量约束循环赛日程表算法

  • 如果队伍数为奇数,则添加一个虚拟队伍来凑成偶数
  • 固定第一支队伍的位置,其他队伍按顺序循环移动
示例
  • 5 5 5个选手的比赛日程表

  • 选手数为奇数,首先添加一个虚拟队伍 6 6 6来凑成偶数,如下图所示

4

  • 1 1 1轮竞争队伍安排,其中与虚拟队伍 6 6 6比赛即为轮空,如下图所示

5

  • 固定队伍 1 1 1的位置,其他队伍按顺序循环移动,得到第 2 2 2轮竞争队伍安排,如下图所示

6

  • 3 3 3 5 5 5轮以此类推

7

Python实现
def generate_schedule(num_teams):
    # 如果队伍数为奇数, 添加一个虚拟队伍来凑成偶数
    if num_teams % 2:
        num_teams += 1

    num_rounds = num_teams - 1  # 总轮数
    half_teams = num_teams // 2  # 每轮比赛场数

    teams = list(range(1, num_teams + 1))

    schedule = []

    for round in range(num_rounds):
        matches = []

        for i in range(half_teams):
            match = (teams[i], teams[num_teams - i - 1])

            matches.append(match)

        schedule.append(matches)

        # 重新排列队伍, 固定第一支队伍, 其他队伍按顺序循环移动
        teams.insert(1, teams.pop())

    return schedule


num_teams = 8

schedule = generate_schedule(num_teams)

round_num = 1
for matches in schedule:
    print(f'Round {round_num}:')

    for match in matches:
        print(f'Team {match[0]} vs Team {match[1]}')

    print()

    round_num += 1
Round 1:
Team 1 vs Team 8
Team 2 vs Team 7
Team 3 vs Team 6
Team 4 vs Team 5

Round 2:
Team 1 vs Team 7
Team 8 vs Team 6
Team 2 vs Team 5
Team 3 vs Team 4

Round 3:
Team 1 vs Team 6
Team 7 vs Team 5
Team 8 vs Team 4
Team 2 vs Team 3

Round 4:
Team 1 vs Team 5
Team 6 vs Team 4
Team 7 vs Team 3
Team 8 vs Team 2

Round 5:
Team 1 vs Team 4
Team 5 vs Team 3
Team 6 vs Team 2
Team 7 vs Team 8

Round 6:
Team 1 vs Team 3
Team 4 vs Team 2
Team 5 vs Team 8
Team 6 vs Team 7

Round 7:
Team 1 vs Team 2
Team 3 vs Team 8
Team 4 vs Team 7
Team 5 vs Team 6

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1637498.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【高质量】2024五一数学建模C题保奖思路+代码(后续会更新)

你的点赞收藏是我后续更新的最大动力! 一定要点击文末的卡片,那是获取资料的入口! 你是否在寻找数学建模比赛的突破点? 作为经验丰富的数学建模团队,我们将为你带来2024 年五一数学建模(C题)…

文心一言 VS 讯飞星火 VS chatgpt (249)-- 算法导论18.2 2题

二、请解释在什么情况下(如果有的话),在调用 B-TREE-INSERT 的过程中,会执行冗余的 DISK-READ 或 DISK-WRITE 操作。(所谓冗余的 DISK-READ ,是指对已经在主存中的某页做 DISK-READ 。冗余的 DISK-WRITE 是…

SpringBoot中阿里OSS简单使用

官方文档:Java跨域设置实现跨域访问_对象存储(OSS)-阿里云帮助中心 1.pom中引入依赖 <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.15.1</version> </dependency> 如…

配置 Trunk,实现相同VLAN的跨交换机通信

1.实验环境 公司的员工人数已达到 100 人&#xff0c;其网络设备如图所示。现在的网络环境导致广播较多网速慢&#xff0c;并且也不安全。公司希望按照部门划分网络&#xff0c;并且能够保证一定的网络安全性。 其网络规划如下。 PC1和 PC3为财务部&#xff0c;属于VLAN 2&…

JavaFX创建桌面应用exe文件以及SceneBuilder使用讲解

文章目录 1 JavaFX1.1 引言1.2 简单使用1.2.1 搭建项目1.2.2 fxml文件1.2.3 生成exe文件 1.3 Idea中集成SceneBuilder1.4 注解讲解1.4.1 FXMLController1.4.2 FXML1.4.3 FXMLLoaderParameters1.4.4 FXMLProperty 1.5 SceneBuilder1.5.1 添加组件ControlsFX1.5.1.1页面展示 1.5.…

【c++】cpp类的继承

目录 &#xff08;1&#xff09;继承概念与语法 &#xff08;2&#xff09;派生类的访问控制 &#xff08;3&#xff09;继承中的构造和析构 1.类型兼容性原则 2.继承中的构造析构调用原则 3.继承与组合混搭下构造和析构调用原则 &#xff08;4&#xff09;同名成员(函数…

OI Wiki—递归 分治

//新生训练&#xff0c;搬运整理 递归 定义 递归&#xff08;英语&#xff1a;Recursion&#xff09;&#xff0c;在数学和计算机科学中是指在函数的定义中使用函数自身的方法&#xff0c;在计算机科学中还额外指一种通过重复将问题分解为同类的子问题而解决问题的方法。 引入…

Python语言零基础入门——模块

目录 一、模块的导入与使用 1.模块的导入 2.模块的使用 二、包的使用 1.包 2.包的使用 三、常见的标准库 1.random的运用举例 2.random小游戏 &#xff08;1&#xff09;石头剪刀布 &#xff08;2&#xff09;猜大小 3.re 4.time库的使用 5.turtle库的使用 6.so…

Zapier 与生成式 AI 的自动化(一)

原文&#xff1a;zh.annas-archive.org/md5/057fe0c351c5365f1188d1f44806abda 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 前言 当组织处理手动和重复性任务时&#xff0c;生产力会遇到重大问题。Zapier 处于无代码运动的前沿&#xff0c;提供了一种先进的工具&a…

【C++】详解string类

目录 简介 框架 构造 全缺省构造函数 ​编辑 传对象构造函数 拷贝构造 析构函数 容量 size() capacity&#xff08;&#xff09; empty() clear() reserve() ​编辑 resize() 遍历 检引用符号"[ ]"的重载 迭代器 begin() end() rbegin() rend(…

【竞技宝】欧冠:拜仁2比2战平皇马,金玟哉状态低迷

拜仁在欧冠半决赛首回合较量中坐镇主场跟皇马相遇,这场比赛踢得非常激烈好看。拜仁并没有在主场苟着踢,而是跟皇马打对攻,让球迷大呼过瘾。最终,拜仁与皇马激战90分钟后,以2比2比分战平。对于这样的比赛结果,大部分拜仁球迷都觉得不服气。因为,他们认为自家中卫金玟哉太差,如果…

3D建模在游戏行业的演变和影响

多年来&#xff0c;游戏行业经历了显着的转变&#xff0c;这主要是由技术进步推动的。 深刻影响现代游戏的关键创新之一是 3D 建模领域。 从像素化精灵时代到我们今天探索的错综复杂的游戏世界&#xff0c;3D 建模已成为游戏开发不可或缺的基石。 本文讨论 3D 建模在游戏行业中…

智能健康管理子卡(ChMC/IPMC)模块,支持IPMI2.0标准通信协议,0Kbps可配置,可通过IPMI命令控制其他刀片开关电,具备故障上报、开机自检

是一款BMC子卡&#xff0c;该子卡输出1路千兆网络接口与千兆交换芯片相连,对外输出1路百兆调试网络接口&#xff0c;对外输出2路8路&#xff08;可选&#xff09;IPMB&#xff08;I2C&#xff09;接口并做隔离处理&#xff08;I2C BUFFER&#xff09;&#xff0c;支持IPMI2.0标…

【代码随想录——链表】

1.链表 什么是链表&#xff0c;链表是一种通过指针串联在一起的线性结构&#xff0c;每一个节点由两部分组成&#xff0c;一个是数据域一个是指针域&#xff08;存放指向下一个节点的指针&#xff09;&#xff0c;最后一个节点的指针域指向null&#xff08;空指针的意思&#…

rust疑难杂症

rust疑难杂症解决 边碰到边记录&#xff0c;后续可能会逐步增加&#xff0c;备查 cargo build时碰到 Blocking waiting for file lock on package cache 原因是Cargo 无法获取对包缓存的文件锁&#xff0c; 有时vscode中项目比较多&#xff0c;如果其中某些库应用有问题&…

脸爱云一脸通智慧管理平台 SystemMng 管理用户信息泄露漏洞(XVE-2024-9382)

0x01 产品简介 脸爱云一脸通智慧管理平台是一套功能强大,运行稳定,操作简单方便,用户界面美观,轻松统计数据的一脸通系统。无需安装,只需在后台配置即可在浏览器登录。 功能包括:系统管理中心、人员信息管理中心、设备管理中心、消费管理子系统、订餐管理子系统、水控管…

Kafka介绍、安装以及操作

Kafka消息中间件 1.Kafka介绍 1.1 What is Kafka&#xff1f; 官网&#xff1a; https://kafka.apache.org/超过 80% 的财富 100 强公司信任并使用 Kafka &#xff1b;Apache Kafka 是一个开源分布式事件流平台&#xff0c;被数千家公司用于高性能数据管道、流分析、数据集成…

CentOS7安装MySQL8.3(最新版)踩坑教程

安装环境说明 项值系统版本CentOS7 &#xff08;具体是7.9&#xff0c;其他7系列版本均可&#xff09;位数X86_64&#xff0c;64位操作系统MySQL版本mysql-8.3.0-1.el7.x86_64.rpm-bundle.tar 实际操作 官网下载安装包 具体操作不记录&#xff0c;相关教程很多。 mkdir /o…

Mysql-黑马

Mysql-黑马 编写规范&#xff1a;## 一级1. 二级三级 1.Mysql概述 数据库概念mysql数据仓库 cmd启动和停止 net start mysql180 net stop mysql180备注&#xff1a;其中的mysql180是服务名 客户端连接 远程连接数据仓库 -h 主机号 -P端口号 mysql [-h 127.0.0.1] [-P 33…

YOLOv5改进之bifpn

目录 一、原理 二、代码 三、在YOLOv5中的应用 一、原理 论文链接: