Cba晋级名单:足球保底 /晋级算法(what is relegation)

关于Cba晋级名单的问题,在what is relegation中经常遇到, 我想知道是否有一种方法可以加快给定足球联赛表的足球(足球)保证促销的计算。似乎问题有很多结构,所以详尽的解决方案可能比必要的要慢。

我想知道是否有一种方法可以加快给定足球联赛表的足球(足球)保证促销的计算。似乎问题有很多结构,所以详尽的解决方案可能比必要的要慢。

在问题中,有一个schedule(一对球队的列表)将在将来互相比赛,并且每个球队在过去的比赛中获得了table(地图)的积分。我在包含了一个示例的现实生活中的积分表。每个未来的比赛都可以赢,输或并列,并且每个球队在获胜时获得 3 分,在正数 / 整数时获得 1 分。

Sample table

问题是要确定哪些(如果有的话)团队目前可以保证晋升。保证晋升意味着无论决赛结果如何,球队最终都必须晋升。

def promoted(num_of_promoted_teams, table, schedule):
   return guaranteed_promotions

我一直在考虑使用深度优先搜索 (对未来的比赛结果) 来淘汰那些会降低平均水平但不会降低最差表现的球队。这肯定会在赛季初有所帮助,但问题可能会在赛季中期变得很大,然后在接近尾声时再次缩小。看起来可能有更好的方法。

1

由于巧妙的修剪算法,约束求解器在实践中应该足够快,并且很难搞砸。这是 OR-Tools CP-SAT 求解器的一些示例代码。

from ortools.sat.python import cp_model
def promoted(num_promoted_teams, table, schedule):
    for candidate in table.keys():
        model = cp_model.CpModel()
        final_table = table.copy()
        for home, away in schedule:
            home_win = model.NewBoolVar("")
            draw = model.NewBoolVar("")
            away_win = model.NewBoolVar("")
            model.AddBoolOr([home_win, draw, away_win])
            model.AddBoolOr([home_win.Not(), draw.Not()])
            model.AddBoolOr([home_win.Not(), away_win.Not()])
            model.AddBoolOr([draw.Not(), away_win.Not()])
            final_table[home] += 3 * home_win + draw
            final_table[away] += draw + 3 * away_win
        candidate_points = final_table[candidate]
        num_not_behind = 0
        for team, team_points in final_table.items():
            if team == candidate:
                continue
            is_behind = model.NewBoolVar("")
            model.Add(team_points < candidate_points).OnlyEnforceIf(is_behind)
            model.Add(candidate_points <= team_points).OnlyEnforceIf(is_behind.Not())
            num_not_behind += is_behind.Not()
        model.Add(num_promoted_teams <= num_not_behind)
        solver = cp_model.CpSolver()
        status = solver.Solve(model)
        if status == cp_model.INFEASIBLE:
            yield candidate
print(*promoted(2, {"A": 10, "B": 8, "C": 8}, [("B", "C")]))
1

这里有一个替代解决方案,它的可扩展性较低,可能较慢,以换取自包含和可。

此解决方案由一个算法组成,该算法用于测试特定团队是否可以在一组特定的其他团队之后完成(假设不利的抢七局),这些团队被包裹在由前 k 个团队和一组 k 个团队组成的成对循环中 W 可能会或可能不会提前完成(其中 k 是晋升团队的数量)。

如果没有平局,那么我们可以使用二分匹配。标记为输掉了剩余的比赛,标记为 W 赢得了与不在 W 中的球队的比赛。在二分图的一侧,有与 W 成员之间的比赛相对应的节点。在另一侧,W 中的每个团队都有零个或多个节点,对应于该团队必须赢得的比赛数才能在前场晋级之前完成。

因此,在最多 k 的所有子集上循环选择 2 对团队,并在将子集中的每对标记为已绘制一次后运行上面的算法。

(我可以提出改进,但是 k 很小,计算机便宜,程序员昂贵,体育迷无情。)

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(941)
班级管理小程序:一个班级中的一个班级 (class within class)
上一篇
K uci:如何使用structuci_section指针从UCI包中删除节
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 23 48
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 69 55
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 59 54
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 77 99
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 42 15
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 57 33
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 36 44
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 55 48

发表评论

登录 后才能评论

评论列表(10条)