用 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