HDU 1850 NIM博弈
2016-03-29 17:41
218 查看
#include <cstdio> const int maxn = 1E2 + 10; int inp[maxn], m, sum, cnt; int main(int argc, char const *argv[]) { while (~scanf("%d", &m) && m) { sum = cnt = 0; for (int i = 0; i < m; i++) scanf("%d", inp + i), sum ^= inp[i]; for (int i = 0; i < m; i++) if ((sum ^ inp[i]) < inp[i]) cnt++; printf("%d\n", cnt); } return 0; }
典型的NIM博弈。有m堆牌,两个人先后取某堆中的任意(不少于一)张牌,最后取完者胜;问先手取胜第一次取牌有多少种取法。
如果是必败态,则没有获胜可能。
若给出的是必胜状态:a1^a2^.......^an=k,(其中k不为零),那么我们的目的是要把必胜状态转化为必败状态
若a1^a2^...^an!=0,一定存在某个合法的移动,将ai改变成ai'后满足a1^a2^...^ai'^...^an=0。
若a1^a2^...^an=k,则一定存在某个ai,它的二进制 表示在k的最高位上是1。这时ai^k<ai一定成立。
则我们可以将ai改变成ai'=ai^k,此时a1^a2^...^ai'^...^an=a1^a2^...^an^k=0。
相关文章推荐
- Android中WebView加载网页时,在顶部加上进度条
- android系统数据库中多个数据表含有变量插入操作
- 关于配置文件
- Eclipse中给jar包导入JavaDoc的方法(javaDoc的用处)
- 虚拟机扩展磁盘--不添加新磁盘
- 机器学习的embedding
- 【bzoj1409】Password 线性筛法+矩阵乘法
- CKplayer
- 4.3.1使用WebRTC搭建前端视频聊天室——信令篇
- 在 OS X 上使用 Vagrant 和 Docker
- android RecyclerView首字母悬浮在顶部,滑动删除
- Core Animation - 如何来绘制三个圆角一个直角的矩形
- finally代码块
- C++第二次作业Plus
- 在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)
- android 蓝牙编程重点---如何发送和接收16进制数据
- 面向对象的优点
- Android手机中的AP与BP
- 把所有文件汇入到一个文件中
- 在Service中使用广播接受者