Round #173 (Div. 2) D. Yet Another Number Game——博弈

题意:大名鼎鼎的威佐夫博弈在n为一到三的版本。

n等于2的时候,就是威佐夫博弈。当n等于三的时候其实就和Nim博弈是等价的了,我们可以证明,当达到一个0状态的时候,无论通过什么操作下一个状态一定是Nim博弈的先手胜的状态,即使是使用威佐夫博弈的操作。

设s = x1 ^ x2 ^ x3,后续状态t = y1 ^ y2 ^ y3,且t = s ^ (x1 ^ y1) ^ (x2 ^ y2) ^ (x3 ^ y3),若s = 0,则t必定为1。

现在就很容易看出:威佐夫博弈在n为奇数的情况下和Nim博弈是等价的。

G = (1 + 5 ** 0.5) / 2
w = set((int(k * G), int(k * G) + k) for k in range(999))
n = input()
a = sorted(map(int, raw_input().split()))
print ["BitLGM", "BitAryo"][n == 2 and (a[0], a[1]) in w or n != 2 and not reduce(lambda x, y : x ^ y, a)]


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值