首页 文章资讯内容详情

在 Python 中查找集合元素移除游戏获胜者的程序

2026-06-03 1 花语

假设我们有一组前n个自然数{1..n}。Amal和Bimal正在玩game.The游戏规则如下

Amal总是先玩

在每次移动期间,当前玩家从集合中选择一个质数p。然后玩家从集合中移除p和它的所有倍数。

谁不动谁输游戏如果我们有n,我们必须找到获胜者的名字。

所以,如果输入像n=5,那么输出将是Amal,因为初始集合是{1,2,3,4,5}。现在让Amal选择一个数p=2,并从集合中移除2,4,所以当前集合为{1,3,5},还剩下两个素数,所以Bimal可以选择其中任何一个但没有剩余元素删除,最后Amal删除另一个素数并赢得比赛。

示例

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

primes = [0 for i in range(100001)] sieve = [0 for i in range(100001)] for i in range(2, 100000): if sieve[i] == 0: primes[i] = primes[i-1]+1 for j in range(i, 100001, i): sieve[j] = i else: primes[i] = primes[i-1] def solve(n): return "Bimal" if primes[n] % 2 == 0 else "Amal" n = 5 print(solve(n))

输入

5输出结果Amal