题目描述
甲,乙两个人玩 Nim 取石子游戏。
Nim 游戏的规则是这样的:地上有 n 堆石子(每堆石子数量小于 10^4),每人每次可从任意一堆石子里取出任意多枚石子扔掉,可以取完,不能不取。每次只能从一堆里取。最后没石子可取的人就输了。假如甲是先手,且告诉你这 n 堆石子的数量,他想知道是否存在先手必胜的策略。
输入格式
本题有多组测试数据。
第一行一个整数 T(T≤10),表示有 TT 组数据
接下来每两行是一组数据,第一行一个整数 nn,表示有 n 堆石子,n≤10000。
第二行有 n 个数,表示每一堆石子的数量.
输出格式
共 TT 行,如果对于这组数据存在先手必胜策略则输出 Yes
,否则输出 No
,每个单词一行。
输入输出样例
输入
2 2 1 1 2 1 0
输出
No Yes
****************************************************************************************************************************************************************
解题思路:这是一道nim博弈的裸题,直接套结论,如果所有的石子异或和等于0则先手必败,否则先手必胜
下面附上ac代码
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <string>
#include <queue>
using namespace std;
typedef long long ll;
ll a[1000010];
int main()
{
std::ios::sync_with_stdio(false);
ll t;
cin>>t;
while(t--)
{
ll n,cur;
cin>>n;
ll ans=0;
for(ll i=1;i<=n;i++)
{
cin>>cur;
ans^=cur;
}
if(ans==0)
cout<<"No"<<endl;
else
cout<<"Yes"<<endl;
}
return 0;
}