2017年浙江工业大学大学生程序设计迎新赛预赛A【巴什博奕 异或和】

链接:https://www.nowcoder.net/acm/contest/52/A
来源:牛客网

题目描述
栗酱特别喜欢玩石子游戏,就是两个人玩,有n堆石子,每堆有ai个,每次一个人可以轮流选择任意一堆,取走任意多的石子(但不能不取),谁先不能取谁输。
栗酱觉得这个游戏很有趣,知道有一天,小太阳告诉她,其实如果两个人足够聪明,游戏的结局一开始就已经注定。
栗酱是一个冰雪聪明的女孩子,她不相信,希望你演示给她看。
输入描述:
多组数据,数据第一行T表示数据组数。
每组数据第一行一个n,k表示一共有n堆石子,接下来你试图从第k堆开始取,从第二行开始,每隔一个空格一个第i堆石子的数量ai。
n≤105, ai≤109
输出描述:
输出“Yes”或“No”代表从该堆开始取是否可以必胜(如果足够聪明)。
示例1
输入

2
3 2
1 2 3
2 1
2 1
输出

No
Yes
说明

小太阳哥哥说,如果想赢,就试图把每堆石子数量的异或和变为0,最终便可以获得胜利,不相信自己证一下。
备注:
小数据较多,不要使用memset,可能导致TLE。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
long long  stone[100002];
int main()
{
    int T;
    int n,k;
    cin>>T;
    while(T--)
    {
        long long  ans = 0;//0^x = x;
        cin>>n>>k;
        for(long long  i = 1;i<=n;i++)
        {
            cin>>stone[i];
            //<<"stone["<<i<<"]:"<<stone[i];
            if(i!=k)//除了首先拿的第k堆,其余堆的异或和
                ans = ans^stone[i];
        }
        //cout<<"ans:"<<ans<<endl;
        if(stone[k]>ans)//如果第k堆的石子大于其余石子的异或和,那么只需拿走多的那部分,使剩余的所有堆的石子异或和为0,则先手必赢
            cout<<"Yes"<<endl;
        else
            cout<<"No"<<endl;
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值