- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
哪种方法最适合尝试在 Switch double 循环赛中平均分配对手,即每轮更换伙伴。
例如,在 8 人锦标赛中,您将进行 7 轮比赛,与每位玩家对战 3 或 4 次,并与每位玩家对战一次。当使用“向右轮换”方法时,对局部分是正确的,但对手分布不均。
最佳答案
几年前,一位 friend 要求我提供一个高尔夫锦标赛循环赛的解决方案。你的问题和那个类似。以下是我将如何解决问题:
这是用于实现此方法的代码:
# Given
players = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H']
from itertools import combinations
from copy import deepcopy
def filterByParties(ptys:list, pairs: list([tuple])) -> list([tuple]):
# return pairs where neither player is in ptys list
return [x for x in pairs if ptys.count(x[0]) == 0 and ptys.count(x[1]) == 0]
# Alternative implementation without using list comprehension
# rslt = []
# ptr = 0
# while ptr < len(pairs):
# pr = pairs[ptr]
# if ptys.count(pr[0]) == 0 and ptys.count(pr[1]) == 0:
# rslt.append(pr)
# ptr += 1
# return rslt
def dropPair(pr:list, pairings: list([tuple])) -> list([tuple]):
# return list of parings minus pr
return [x for x in pairings if pr[0] != x[0] or pr[1] != x[1]]
# Alternative implementation without using list comprehension
# ptr = -1
# for i, pair in enumerate(pairings):
# if pr[0] == pair[0] and pr[1] == pair[1]:
# ptr = i
# break
# if ptr >= 0:
# pairings.pop(ptr)
# return pairings
def doublesTournament(players: list([str])):
# Given list of players, produce a listing for a doubles tennis tournament
# Where the tournament is split into rounds of play in which all players
# play matches with the different participants
tournament_pairings = list(combinations(players, 2))
tournament_rounds = len(players) -1
matches_per_round = len(players)//4
tournament_schedule = []
for rnd in range(tournament_rounds):
rnd_play_list = []
# Make true copy of parinings for assigning match play
match_pairings = deepcopy(tournament_pairings)
while match_pairings:
team_one = match_pairings.pop()
match_pairings = filterByParties(team_one, match_pairings)
tournament_pairings = dropPair(team_one, tournament_pairings)
team_two = match_pairings.pop()
match_pairings = filterByParties(team_two, match_pairings)
tournament_pairings = dropPair(team_two, tournament_pairings)
rnd_play_list.append((team_one, team_two))
tournament_schedule.append(rnd_play_list)
for r, round_play in enumerate(tournament_schedule):
print(f'Round {r+1}')
for m, match_play in enumerate(round_play):
print(f'\tMatch {m+1}: {match_play[0]} vs {match_play[1]}')
doublesTournament(players)
产量:
Round 1
Match 1: ('G', 'H') vs ('E', 'F')
Match 2: ('C', 'D') vs ('A', 'B')
Round 2
Match 1: ('F', 'H') vs ('E', 'G')
Match 2: ('B', 'D') vs ('A', 'C')
Round 3
Match 1: ('F', 'G') vs ('E', 'H')
Match 2: ('B', 'C') vs ('A', 'D')
Round 4
Match 1: ('D', 'H') vs ('C', 'G')
Match 2: ('B', 'F') vs ('A', 'E')
Round 5
Match 1: ('D', 'G') vs ('C', 'H')
Match 2: ('B', 'E') vs ('A', 'F')
Round 6
Match 1: ('D', 'F') vs ('C', 'E')
Match 2: ('B', 'H') vs ('A', 'G')
Round 7
Match 1: ('D', 'E') vs ('C', 'F')
Match 2: ('B', 'G') vs ('A', 'H')
关于python - 在 "Switch Doubles Round Robin Tournament"平分对手,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70055258/
是否有使用 switch 语句检查数字 0-9 的简单方法?我正在编写一个程序来检查某些字符和数字。就像检查“\0”、“F”或“f”一样,想知道是否还有一种方法可以以类似的方式检查 0-9。我知道我可
我有一些数据需要转换,为此我需要一个超过 50 个案例的切换条件,我需要 3 次相同的案例,但在第三次我需要 50 个案例和一些更多,我不想写两次相同的代码。也许有可能做这样的事情。 switch (
我遇到这种情况,我必须检查两个 GET 变量。在检查语句内的第一个 switch 语句后,必须在第一个 case 循环内的第二个 switch 语句中检查第二个变量。 我无法在这里发布确切的代码,但这
如何使用函数指针代替 switch 语句? 最佳答案 与 ars 发布的链接略有不同的方法:您可以将 switch 语句中的值用作函数指针数组中的数组索引。所以不要写 switch (i) {
我必须评估很多条件。就我而言,我必须做这样的事情: switch(id) { case 5: // switch some other cases here case
switch 按钮位于 switch 语句内,但仅在 switch 语句外部时才有效这是我的代码:
我试图在 switch 语句中有一个 case 跳转到不同的 switch 语句。 在实践中,我希望用户在文本框中键入“关闭页面”,并且在浏览器关闭页面之前,我希望询问用户是否确定。输入“yes”将关
(引用java)我试图确定哪个更好,编写更多代码并可能节省一些计算时间,或者编写更少代码但可能牺牲一些计算时间。这就是我好奇的地方这样做会更有效率吗: switch (availability) {
我正在尝试构建一个 Android 应用程序,该应用程序可以访问加速度计传感器,并在单击按钮时将加速度计值(由 <> 包围)输出到串行 USB。当我更新值并尝试在 onClick 命令中调用它时遇到问
如何使用 Dwoo 模板引擎实现 switch case 语法。 最佳答案 {if 3 == 5} never gonna happen {elseif 3 == 3} if you don'
我想知道一个大的 switch 语句和几个小的 switch 语句之间是否有性能差异。 包含数百个案例的大型 switch 语句。 switch(quest){ case 1:
用户在 2 个选择框中进行选择后,我尝试计算出报值(value)。 看起来 1 需要 2 个 switch 语句。这可能吗? (可能的值比下面的值多得多。为了清楚起见,我删除了它们) var wor
我在主 while 循环内有一个开关,它将运行我的游戏。我正在尝试打破我的开关,以便转到不同的案例。下面的例子更好地解释了这一点: int j = 0; While(1){ switch(j){ ca
我用 Java 创建了一个菜单,其中每个选项都有另一个菜单。我想知道是否可以从内部菜单退出回到主菜单。 编辑:添加了主菜单选项 System.out.println("Main Menu");
我有一个计算新分数的方法。下面的方法有效,但问题是代码本身看起来可以被显着清理。我只是不知道什么是最好的方法。我根据 filterString 和枚举 individualScoreState 分配
在 Lisp 中使用字符串切换语句。 (defun switch(value) (case value (("XY") (print "XY"))
我想做这样的事情: int i = 0; switch(difficulty) { case 1: i++; break; case 2: i--; break; defaul
在 Obj-c 中,我做了一个 switch 语句,我曾经使用 UIsplitviewcontroller 在我的 iPad 应用程序中四处移动现在我想快速地做同样的事情……我试了几个小时,现在我唯一
我想写一个结构如下的报告: \begin{document} \input[option=a]{class} \input[option=b]{class} \in
我正在认真阅读 ngSwitch 的 AngularJS API 引用。当我谈到那部分时的指令: place an expression on the on="..." attribute (or t
我是一名优秀的程序员,十分优秀!