用 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