传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1022
刚开始以为是SG裸题……然后就WA了一发……
仔细推了推发现好像不太对,最后得到以下结论
先手(John)赢的条件为:
(1)所有堆都为1,SG值为0。
(2)存在堆大于1,SG值不为0。
#include<stdio.h>
int T,n,ans;
int main()
{
scanf("%d",&T);
while (T--)
{
ans=0;bool f=1;
scanf("%d",&n);
for (int i=1,k;i<=n;i++)
{
scanf("%d",&k);
ans^=k;
if (1<k) f=0;
}
puts((ans^f)?"John":"Brother");
}
}
本文通过一道具体题目探讨了博弈论中的一种游戏算法实现。详细分析了先手玩家获胜的两种情况,并给出了相应的C语言代码实现。对于理解博弈论中的游戏策略及SG函数的应用具有一定的参考价值。
350

被折叠的 条评论
为什么被折叠?



