- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我需要制定体育赛事的时间表。
有 30 个团队。每支球队必须打8场比赛。这意味着每个团队不可能再次与所有其他团队竞争,但我需要避免两个团队相互竞争不止一次。
我的想法是生成所有可能的匹配项(对于 30 个团队:(30*29)/2 = 435 个匹配项
)并从此列表中选择 120 个匹配项(每个团队 8 个匹配项:8 * 30/2 = 120 个匹配项
)。
这是我遇到困难的地方:如何选择这 120 个匹配项?我尝试了一些简单的解决方案(取列表中的第一个匹配项,然后是最后一个,依此类推)但它们似乎不适用于 30 个团队。我还尝试生成所有可能的匹配组合并找出哪个有效,但是对于 30 个团队,这计算时间太多了。
是否有我可以实现的现有算法?
更新
我需要制作的是一个简单的时间表,没有淘汰。每支球队打8场比赛,仅此而已。在一天结束时,不会有一个赢家。
每支队伍都会有自己的赛程,这个赛程无论输赢都不会改变。计划是一整天都完成的,并且是不可变的。
更新 2
起初,我不想对我的问题施加太多限制,但似乎没有任何限制(除了每个团队相互竞争不超过一次),这只是随机选择 8 的问题每个团队的比赛。
所以这里有一些更多的细节:
在这项运动赛事中,有 6 种不同的运动项目(足球、手球、篮球等)。这意味着同时有 6 场比赛。每 15 分钟开始新一轮。
每支球队必须参加 8 场比赛,每项运动至少进行一次。
这 6 项运动在三个不同的地方进行。这意味着在白天,每个团队都必须从一个地方移动到另一个地方。应尽可能减少这些 Action 。
一支球队不能连续打两场比赛。
最佳答案
您可以研究一些已知的匹配方法:
编辑:
再次阅读您的要求后 - 每支球队都应该与其他球队比赛恰好一次,而且不一定要决定获胜者。好像是单Round Robin系统会做你想做的。您可以将任何额外的对局放在您需要的 8 个以上。
关于algorithm - 策划一场比赛,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2941911/
鉴于我使用 matches!宏观 当我尝试将它与枚举一起使用时 然后它显示出意想不到的行为。 请参阅以下最小示例,playground 中也提供了该示例 pub enum Test { FIR
鉴于我使用 matches!宏观 当我尝试将它与枚举一起使用时 然后它显示出意想不到的行为。 请参阅以下最小示例,playground 中也提供了该示例 pub enum Test { FIR
我使用 pcrecpp c++ (PCRE lib) 我需要循环获取所有匹配项。我该怎么做? 例如模式: “你好” 和主题: “你好你好” 循环应该循环 3 次(因为 3 次匹配) 1 你好 2
循环赛算法在每场比赛只有团队相遇时工作正常。但是,如何在超过两支球队在同一场比赛中相遇的体育比赛或比赛中实现它。例如彩弹射击锦标赛,其中 2 到 n 个团队在 2 到 n 场比赛中相遇。仍然保持尽可能
http://ecoocs.org/contests/ecoo_2007.pdf 我正在为我所在地区即将举行的 ecoo regionals 学习,但我对这个问题感到困惑。我真的不知道从哪里开始。 它
如果有人可以帮助我使用二维数组概念而不是使用集合,那就太好了。因为我必须在这个逻辑中使用数组并获取输出。 问题: 第 1 组有四支球队,名称分别为(“A”、“B”、“C”、“D”)第 2 组有四支球队
我几乎正在尝试重新开始 JAVA 编程,只是需要一些我正在从事的小项目的指导。 差不多,我正在举办一场台球锦标赛,我希望每个玩家都能与每个玩家交手一次: 我创建了该程序( https://sconte
我遇到了这个问题,但无法想出解决方案。有一场 Frog 赛跑, Frog 有一定数量的有效跳步。它可以向前或向后移动。为了赢得比赛, Frog 必须尽可能靠近终点线,但不能越过终点线。 例子。6, 1
Closed. This question needs to be more focused。它当前不接受答案。
我正在为篮球赛季创建一个数据库。在这一点上,我保持简单,并存储表: -联盟 id[PK], name->(NBA, NCAAM, etc) -年 id[PK], league_id[FK], year
我将在当前工作的网站上创建竞赛。每个比赛都不会相同,并且可能有不同数量的输入字段,用户必须输入这些字段才能成为比赛的一部分,例如。 比赛 1 可能只需要一个名字 比赛 2 可能需要名字、姓氏和电子邮件
我正在尝试执行一个查询,该查询可以返回 5 个条件中的大多数匹配的结果。但如果只有 5 场比赛中的 5 场比赛,则优先。 为了说明我的问题,已准备好以下 SQL。 declare @tmp table
我已将所有 Json 转换器放在一个文件 JsonUtil 中,然后有一个 ConvertToJson 方法,该方法尝试转换传递给 json 的任何对象。 基本上是这样的结构: implicit va
我是一名优秀的程序员,十分优秀!