用 Python 计算锦标赛中比赛次数的程序

假设我们有一个数字 n。因此,锦标赛中有 n 支球队有一些规则 -

  • 如果当前团队的数量是偶数,那么每个团队都会与另一个团队合并。总共进行了 (n/2) 场比赛,从中 (n/2) 获胜的球队将进入下一轮。

  • 如果球队数量为奇数,则其中一支球队在锦标赛中随机移动,其余球队合并。因此总共进行了 (n-1)/2 场比赛,并且 (n-1)/2+1 支球队作为获胜者进入下一轮。

我们必须找到比赛的总数,以便我们获得最终的胜利者。

因此,如果输入类似于 n = 10,那么输出将为 9,因为

  • 最初会有5-5个师,其中5个是合格的

  • 现在传一队到比赛,分成2-2队,所以3队将获得资格

  • 现在传一队进入比赛并分1-1队,所以2队将获得资格

  • 以 1-1 平分,其中一位将获得获胜者的资格。

示例(Python)

让我们看看以下实现以获得更好的理解 -

def solve(n):

   ans = 0

   while n != 1:

      f = n//2

      remainder = n % 2

      ans += f

      n = f + remainder

   return ans

n = 10

print(solve(n))

输入

10
输出结果
9

以上是 用 Python 计算锦标赛中比赛次数的程序 的全部内容, 来源链接: utcz.com/z/327524.html

回到顶部