【问题标题】:Randomly distribute a seed spot to 128 teams using php使用 php 将种子点随机分配给 128 个团队
【发布时间】:2020-05-30 10:50:51
【问题描述】:

我有 128 支队伍参加单淘汰赛。我想实现以下目标:

  1. 按一个按钮可以让这些球队随机面对对方(意味着 64 场比赛)
  2. 了解如果你赢了,你将在下一场比赛中被分到哪里,以及你将面对谁

目前我的数据库有这些表:

  • 团队(500 个团队的列表)
  • 锦标赛(这个锦标赛例如是 id = 1)
  • 参与(128 支希望参加锦标赛 id = 1 的球队的列表)
  • 匹配(这是我需要以某种方式随机添加团队 1 和团队 2 并且还知道他们在括号中的位置)

目前我有匹配表:

  1. 身份证
  2. tournament_id
  3. 回合(128 支球队的锦标赛最多可以进行 7 回合:128 / 64 / 32 / 16 / 8 / 4 / 2
  4. 游戏(意思是在它所在的支架上,我这样想我可以定义第 2 轮有第 1 轮的第 1 场和第 2 场比赛等。不确定这是一个好主意)
  5. team1_id
  6. team2_id
  7. team1_score
  8. team2_score
  9. winner_team_id
  10. 状态

有人有这方面的经验吗?

谢谢。

【问题讨论】:

    标签: php algorithm


    【解决方案1】:

    随机选择teams中的所有行:

    SELECT * FROM teams ORDER BY RAND()
    /* Or: https://dba.stackexchange.com/questions/955/what-is-the-best-way-to-get-a-random-ordering */
    

    使用 PHP:对于您检索的每两行,在 match 中插入一行,使用第一个团队的 teams.id 作为team1_id 和第二个团队的 teams.id 作为 team2_id,并填写其他字段相应地。

    【讨论】:

      猜你喜欢
      • 2016-10-11
      • 1970-01-01
      • 2015-03-22
      • 1970-01-01
      • 1970-01-01
      • 2022-11-23
      • 1970-01-01
      • 2023-03-28
      • 1970-01-01
      相关资源
      最近更新 更多