栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Python中的联赛夹具生成器

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python中的联赛夹具生成器

夹具调度是一个众所周知的问题。这是算法的python实现,网址为:http : //en.wikipedia.org/wiki/Round-
robin_tournament

# generation pre - for cut and pasteimport operatordef fixtures(teams):    if len(teams) % 2:        teams.append('Day off')  # if team number is odd - use 'day off' as fake team    rotation = list(teams)       # copy the list    fixtures = []    for i in range(0, len(teams)-1):        fixtures.append(rotation)        rotation = [rotation[0]] + [rotation[-1]] + rotation[1:-1]    return fixtures# demo preteams = ["Team1", "Team2", "Team3", "Team4", "Team5"]# for one match each - use this block onlymatches = fixtures(teams)for f in matches:        print zip(*[iter(f)]*2)# if you want return matches reverse_teams =  [list(x) for x in zip(teams[1::2], teams[::2])]reverse_teams = reduce(operator.add,  reverse_teams)    # swap team1 with team2, and so on ....#then run the fixtures againmatches = fixtures(reverse_teams)print "return matches"for f in matches:        print f

生成输出:

[('Team1', 'Day off'), ('Team2', 'Team5'), ('Team3', 'Team4')][('Team1', 'Team5'), ('Day off', 'Team4'), ('Team2', 'Team3')][('Team1', 'Team4'), ('Team5', 'Team3'), ('Day off', 'Team2')][('Team1', 'Team3'), ('Team4', 'Team2'), ('Team5', 'Day off')][('Team1', 'Team2'), ('Team3', 'Day off'), ('Team4', 'Team5')]


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/639666.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号