栗酱的异或和

时间限制:C/C++ 1秒,其他语言2
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld

题目描述

        栗酱特别喜欢玩石子游戏,就是两个人玩,有n堆石子,每堆有ai个,每次一个人可以轮流选择任意一堆,取走任意多的石子(但不能不取),谁先不能取谁输。
        栗酱觉得这个游戏很有趣,知道有一天,小太阳告诉她,其实如果两个人足够聪明,游戏的结局一开始就已经注定。
        栗酱是一个冰雪聪明的女孩子,她不相信,希望你演示给她看。

输入描述:

多组数据,数据第一行T表示数据组数。
每组数据第一行一个nk表示一共有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<bits/stdc++.h>

using namespace std;

int main()

{

    int T;

    cin>>T;

    while(T--)

    {

        int n,k,num;

        cin>>n>>k;

        int sum=1,it;

        for(int i=1;i<=n;i++)

        {

            cin>>num;

            if(i!=k)

                sum^=num;

            else

                it=num;

        }

        if(it>sum)

            cout<<"Yes"<<endl;

        else

            cout<<"No"<<endl;

    }

    return 0;

}

一位大神给的思路:sum算的是异或的和,只有指定位置开始的那个没有异或,一个值异或一个值相同为0,不同为1,最后只判断指定那个值和sum的大小就可以了,然后it>sum是因为不能一个不拿,不能写等于。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值