问题
http://hihocoder.com/problemset/problem/1173
代码
Sprague-Grundy
#include <bits/stdc++.h>
using namespace std;
int main()
{
int n;
scanf("%d", &n);
int ret =0;
for(int i=0; i<n; ++i)
{
int a;
scanf("%d", &a);
if (a%4==0) --a;
else if (a%4==3) ++a;
ret^= a;
}
printf("%s\n", ret==0?"Bob":"Alice");
return 0;
}
本文通过一个具体的编程问题实例介绍了Sprague-Grundy算法的应用。该算法主要用于解决博弈论中的 impartial game(无偏游戏),并通过代码示例展示了如何使用此算法来确定在特定情况下哪个玩家将获胜。
6012

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



