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

文章目录

    • @[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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MySQL利用变量进行查询操作

新建连接,自带world数据库,里面自带city表格。 # MySQL利用变量进行查询操作 set cityNameHaarlemmermeer; select * from city where NamecityName;# 多个结果查询 set cityName1Haarlemmermeer; set cityName2Breda; set cityName3Willemstad; selec…

友思特分享 | 激发专属跃迁:用于皮肤医美和光学研究种子源的DPSS激光器

导读 紧凑、坚固、稳定和提供高质量光束的友思特DPSS激光器因其卓越的性能,可作为激光种子源,广泛应用于皮肤医美、非线性光学OPO,以及全息投影技术。 激光(Laser)的诞生是上个世纪科学技术的巨大飞跃,其发…

【工具】如何提取一个mp4文件的关键帧

文章目录 怎么做如何安装ffmepgUbuntu 或 DebianCentOS 或 FedoramacOSWindows其他 Linux 发行版 实践什么是关键帧 怎么做 你可以使用ffmpeg这个强大的多媒体处理工具来提取mp4文件中的关键帧。以下是一个示例命令,可以使用ffmpeg从mp4文件中提取关键帧&#xff1…

Ansible-inventory和playbook

文章目录 一、inventory 主机清单1、列表表示2、inventory 中的变量3、变量3.1 主机变量3.2 组变量3.3 组嵌套 二、playbook剧本1、playbook的组成2、编写剧本2.1 剧本制作2.2 准备nginx.conf2.3 运行剧本2.4 查看webservers服务器2.5 补充参数 3、剧本定义、引用变量3.1 剧本制…

java爬虫代理ip(java爬虫代码示例)

java爬虫代理ip 在编写java爬虫时,经常会遇到需要使用代理IP来访问目标网站的情况。这时候,我们就需要编写代码来实现代理IP的功能。接下来,我们将为大家介绍如何在java爬虫中使用代理IP,以及给出相应的代码示例。 首先&#xff…

聚观早报 | 苹果新款iPad Pro发布;国产特斯拉4月交付量

聚观早报每日整理最值得关注的行业重点事件,帮助大家及时了解最新行业动态,每日读报,就读聚观365资讯简报。 整理丨Cutie 5月9日消息 苹果新款iPad Pro发布 国产特斯拉4月交付量 iOS 18新功能爆料 真我GT Neo6续航细节 三星Galaxy Z F…

Linux——守护进程化(独立于用户会话的进程)

目录 前言 一、进程组ID与会话ID 二、setsid() 创建新会话 三、daemon 守护进程 前言 在之前,我们学习过socket编程中的udp通信与tcp通信,但是当时我们服务器启动的时候,都是以前台进程的方式启动的,这样很不优雅&#xff0c…

限时优惠||新算法转让(一种基于数学的元启发式算法)新的群智能算法转让,新的元启发式算法转让(独家发售)【仅售1份】

新算法 ||新算法转让、新的元启发式算法转让 ||一种基于数学开发的超隐喻的元启发式算法新算法 限时发售、限量1份 1️⃣完整的封装代码 2️⃣配套完整的灵感及数据 3️⃣测试集(3个) (1)cec2017(10、30、50和100维&a…

搞笑聊天截图,几分钟一条原创爆款,多平台发布

利用男女搞笑聊天截图制作原创 这种在抖音很常见相信你也刷到过,这种视频做起来很简单,但是他的点赞很高,只需要搭配好文案就OK, 这种视频通过课程完成之后都是原创视频,我们可以去发抖音,进行中视频变现…

Linux 操作系统网络编程2

1、TCP服务器编写流程 头文件&#xff1a; #include <sys/socket.h> 1.1 创建套接字 函数原型&#xff1a; int socket(int domain, int type, int protocol); 参数&#xff1a; domain: 网域 AF_INET &#xff1a; IPv4 AF_INET6 &a…

docker-compose安装 人大金仓数据库

下载官网安装包 将安装包重命名为: kingbase.tar 再导入镜像仓库 docker load -i kingbase.tar目录创建data文件夹创建docker-compose文件 version: 3 services: kingbase: image: kingbase:v1 container_name: kingbaseports: - "54321:54321" volumes: -…

Core_Air724UG学习

产品描述 Core_Air724UG核心板是基于Air724UG cat1模板制作的开发实验板。 该模块支持Lua二次开发或AT指令&#xff0c;方便开发者根据自己的需求灵活选择。 Core_Air724UG核心板专注于小型化&#xff0c;PCB尺寸4246mm&#xff0c;有12x22哥标准2.54mm排针管脚&#xff0c;其…

IT项目管理-大题【太原理工大学】

一、根据进度网络写出时间参数表、关键路径、总工期 此类题一般是给一个表&#xff0c;问三问。 第一问会问某个活动的时间参数&#xff0c;但我们需要把整个表都求出来&#xff0c;否则单求一个很困难&#xff08;如果你就是不想求整张表也行&#xff0c;不是硬性要求&#xf…

HR招聘面试,如何测评候选人的执行力和岗位胜任力

执行力是人才测评中的重要组成&#xff0c;尤其是对于小微企业那就更加重要了&#xff0c;几乎每个岗位都需要员工有独挡一面的能力&#xff0c;没有执行力的员工是无法在中小企业生存的&#xff0c;那么对于大型企业来说&#xff0c;是不是执行力不重要&#xff1f;非也&#…

JAVA链表相关习题2

1.反转一个单链表。 . - 力扣&#xff08;LeetCode&#xff09; //2在1前面 //1在3前面 //ListNode curhead.next //head.nextnull(翻转后头节点变为最后一个节点) // while(cur ! null) { //记录 当前需要翻转节点的下一个节点 ListNode curNext cu…

谷粒商城实战(022 业务-订单模块-服务调用)

Java项目《谷粒商城》架构师级Java项目实战&#xff0c;对标阿里P6-P7&#xff0c;全网最强 总时长 104:45:00 共408P 此文章包含第267p-第p270的内容 远程调用 订单服务调用客户服务的查询收货地址信息方法 1.在订单服务里添加EnableFeignClients 来开启远程调用功能 2.…

【Scala---04】函数式编程 『 函数 vs 方法 | 函数至简原则 | 函数式编程』

文章目录 1. 函数 vs 方法1.1 方法(1) 定义方法(2) 运算符即方法 1.2 函数(1) 定义函数(2) 匿名函数 1.3 方法转为函数1.4 可变参数&默认参数 2. 函数至简原则3. 函数式编程3.1 函数式编程思想3.3 函数柯里化&闭包3.5 递归 & 尾递归 4. 补充4.1 访问元祖元素4.2 &g…

TCP 连接,一端断电和进程崩溃有什么区别?

TCP 连接&#xff0c;一端断电和进程崩溃有什么区别&#xff1f; 前言主机崩溃进程崩溃有数据传输的场景客户端主机宕机&#xff0c;又迅速重启客户端主机宕机&#xff0c;一直没有重启 总结 前言 有的小伙伴在面试腾讯的时候&#xff0c;遇到了这么个问题&#xff1a; 这个属…

一键审计 web 日志(teler)

在 web 系统遭受攻击之后&#xff0c;通常要审计 web 日志来寻找蛛丝马迹&#xff0c;那么有没有可以满足需求的自动化工具呢&#xff1f;今天就来尝试一款开源工具 teler&#xff0c;项目地址&#xff1a; https://github.com/kitabisa/teler/ 先来看一张作者测试图&#xff1…

NPDP|传统行业产品经理如何跨越鸿沟,从用户角度审视产品

随着科技的飞速发展和互联网的普及&#xff0c;产品经理的角色已经从单纯的产品规划者逐渐转变为全方位的用户体验设计者。对于传统行业的产品经理来说&#xff0c;这是一个挑战与机遇并存的时代。他们不仅要面对激烈的市场竞争&#xff0c;还要学会如何跨越与新兴科技行业之间…