2017浙工大院赛预赛 A 栗酱的异或和 【NIM】
来源:互联网 发布:windows sdk自定义消息 编辑:程序博客网 时间:2024/04/30 03:16
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld
题目描述
栗酱特别喜欢玩石子游戏,就是两个人玩,有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。
分析:第一步取子操作收到了限制,判断先手能否使得总异或值为0。即第K堆的元素是否多于剩下的所有有元素异或之和。
#include<iostream>#include<cstring>#include<cstdio>#include<algorithm>using namespace std;#define ll long long int#define INF 0x3f3f3f3fconst int maxn = 1e5 + 10;ll a[maxn];int main(){ int T; int n; int k; scanf("%d", &T); while (T--) { scanf("%d", &n); scanf("%d", &k); ll tmp = 0; ll ans = 0; for (ll i = 1; i <= n; i++) { scanf("%lld", &a[i]); if (i != k) ans = ans^a[i]; } bool flag = 0; if (a[k]>ans) flag = 1; if (flag) printf("Yes\n"); else printf("No\n"); } return 0;}
阅读全文
0 0
- 2017浙工大院赛预赛 A 栗酱的异或和 【NIM】
- 2017浙工大院赛预赛 I 栗酱数数【water】
- 2017浙工大院赛预赛 J 裁缝大师【几何】
- 2017浙工大院赛预赛 D 简单的数据结构【双端队列||数组模拟】
- 2017浙工大院赛预赛 K 栗酱的连通图【water】L 取数游戏 M【water】 小杰的签到题【模拟】
- 2017浙工大院赛预赛 F 小妈妈找蝌蚪【dijkstra】
- nowcoder 2017年浙江工业大学大学生程序设计迎新赛预赛-栗酱的异或和
- ZOJ 3591 Nim (连续子序列异或和)
- 2017年浙江工业大学大学生程序设计迎新赛预赛-K:栗酱的连通图(最大生成树)
- 2017 浙工业院赛预赛 G 最优屏障【RMQ】
- Nim游戏,异或解决问题,神证明
- bzoj 4589: Hard Nim 异或规则下的多项式乘法
- 【HDU5650 BestCoder Round 77 (div2) A】【水题】so easy 集合所有子集异或和的异或和
- nowcoder 2017年浙江工业大学大学生程序设计迎新赛预赛-CC的神奇背包
- itat的预赛
- 栗酱的异或和(取石子问题)
- 2011年 蓝桥杯 预赛 Java本科A组 试题和答案
- 2017第八届浪潮杯山东省赛 A.Return of the Nim 博弈
- python菱形
- C# 加密算法
- 2017年12月编程语言排行榜:Kotlin成最强黑马,C语言再次崛起
- 组件之爸爸只单传儿子数据
- CSDN-markdown编辑器的基本用法
- 2017浙工大院赛预赛 A 栗酱的异或和 【NIM】
- Linux安装回收站工具
- 写给自己
- java实现二分法
- 2017浙工大院赛预赛 D 简单的数据结构【双端队列||数组模拟】
- 2017浙工大院赛预赛 I 栗酱数数【water】
- 图论算法-Tarjan模板 【缩点;割顶;双连通分量】
- 初次接触java
- miniui tab 条件增加