Being a Good Boy in Spring Festival

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 6842    Accepted Submission(s):
4144

Problem Description
一年在外 父母时刻牵挂
春节回家
你能做几天好孩子吗
寒假里尝试做做下面的事情吧

陪妈妈逛一次菜场
悄悄给爸爸买个小礼物
主动地 强烈地
要求洗一次碗
某一天早起 给爸妈用心地做回早餐

如果愿意 你还可以和爸妈说
咱们玩个小游戏吧
ACM课上学的呢~

下面是一个二人小游戏:桌子上有M堆扑克牌;每堆牌的数量分别为Ni(i=1…M);两人轮流进行;每走一步可以任意选择一堆并取走其中的任意张牌;桌子上的扑克全部取光,则游戏结束;最后一次取牌的人为胜者。
现在我们不想研究到底先手为胜还是为负,我只想问大家:
——“先手的人如果想赢,第一步有几种选择呢?”

 
Input
输入数据包含多个测试用例,每个测试用例占2行,首先一行包含一个整数M(1<M<=100),表示扑克牌的堆数,紧接着一行包含M个整数Ni(1<=Ni<=1000000,i=1…M),分别表示M堆扑克的数量。M为0则表示输入数据的结束。
 
Output
如果先手的人能赢,请输出他第一步可行的方案数,否则请输出0,每个实例的输出占一行。
 
Sample Input
3
5 7 9
0
 
Sample Output
1
 

[定理1]:对于任何一个S态,总能从一堆火柴中取出若干个使之成为T态。

证明:

若有n堆火柴,每堆火柴有A(i)根火柴数,那么既然现在处于S态,

c = A(1) xor A(2) xor … xor A(n) > 0;

  把c表示成二进制,记它的二进制数的最高位为第p位,则必然存在一个A(t),它二进制的第p位也是1。(否则,若所有的A(i)的第p位都是0,这与c的第p位就也为0矛盾)。

那么我们把x = A(t) xor c,则得到x < A(t).这是因为既然A(t)的第p位与c的第p位同为1,那么x的第p位变为0,而高于p的位并没有改变。所以x < A(t).而

A(1) xor A(2) xor … xor x xor … xor A(n)

= A(1) xor A(2) xor … xor A(t) xor c xor … xor A(n)

= A(1) xor A(2) xor… xor A(n) xor A(1) xor A(2) xor … xor A(n)

   = 0

  这就是说从A(t)堆中取出 A(t) - x 根火柴后状态就会从S态变为T态。证毕

•对于某个局面(a1,a2,...,an),若a1^a2^...^an==k(k>0)
•一定存在某个合法的移动,将ai改变成ai'后满足 a1^a2^...^ai'^...^an=0
•一定存在某个ai,它的二进制表示在k的最高位上是1 (ai^k<ai 成立)
•将ai改变成ai'=ai^k a1^a2^...^ai'^...^an=a1^a2^...^an^k=0
 有了这个,我们就可以直接找含有最高位为1的值就可以了,但是一定要注意,找到最高位为1后还要判断ai^k<ai,因为有可能有K值的最高位并不是在ai中,譬如k=1,10^K>10.
 
#include<iostream>
#include<cstdio>
#include<cstring>
#include<stdlib.h>
#include<algorithm>
#include<cmath>
using namespace std; int N[];
int main()
{
int m;
while(scanf("%d",&m)!=EOF&&m)
{
int k=;
for(int i=; i<m; i++)
{
scanf("%d",&N[i]);
k^=N[i];
}
if(k==)
printf("0\n");
else
{
int pos=;
for(int i=;i<=;i++)
{
int tmp=(<<i);
if((tmp&k)>)
pos=i;
}
//cout<<pos<<endl;
int res=;
for(int i=;i<m;i++)
if((N[i]&(<<pos))>&&(N[i]^k)<N[i])
res++;
printf("%d\n",res);
}
}
return ;
}

最新文章

  1. PHP store session with couchbase
  2. 35、重新复习html与css(1)
  3. 【转】XPath的学习
  4. 【leetcode❤python】242. Valid Anagram
  5. 最大子列和CT 01-复杂度2 Maximum Subsequence Sum
  6. UVa401 回文词
  7. VxWorks 6.9 内核编程指导之读书笔记 -- 多任务
  8. [OpenXml] Generate excel in memory and dump to file
  9. android: ListView历次优化
  10. Codeforces Round #277.5 (Div. 2)-D
  11. 怎样在屏幕上显示多个alv
  12. μCos-ii学习笔记2_任务管理
  13. sql 日结
  14. HBase源码实战:ImportTsv
  15. Note | 常用指令和教程
  16. GRASP软件设计的模式和原则
  17. 删除maven仓库中的LastUpdated文件
  18. c#泛型TryParse类型转换
  19. [C#]使用Windows Form开发的百度网盘搜索工具
  20. Can&#39;t find model &#39;en&#39;

热门文章

  1. 重庆OI2017 老 C 的任务
  2. poj 2031
  3. BZOJ1193 马步距离 (贪心)
  4. 20180629利用powerdesigner生成数据字典
  5. 运维系列之一 Linux的文件与目录权限解析
  6. hdu_1018_Big Number_201308191556
  7. [转]十五天精通WCF——第十三天 用WCF来玩Rest
  8. 解决ubuntu上opengl的问题
  9. HDU 4598
  10. Framebuffer 机制【转】