uva 1482 - Playing With Stones(Nim游戏)
2014-08-05 23:27
417 查看
题目链接: uva 1482 - Playing With Stones
题目大意:n堆石子,给定每堆石子的个数,两个人分别从操作,每次可以从一堆中取走至少一个石子,但是不能超过一半。如果不能操作则视为失败。
解题思路:对于每一堆式子来说,可以看作一个Nim游戏,但是SG(x)并不等于x,因为每次取石子不能超过一半,所以对于偶数SG(x)=x/2,对于奇数SG(x)=SG(x/2).
所以去Nim和即可。
题目大意:n堆石子,给定每堆石子的个数,两个人分别从操作,每次可以从一堆中取走至少一个石子,但是不能超过一半。如果不能操作则视为失败。
解题思路:对于每一堆式子来说,可以看作一个Nim游戏,但是SG(x)并不等于x,因为每次取石子不能超过一半,所以对于偶数SG(x)=x/2,对于奇数SG(x)=SG(x/2).
所以去Nim和即可。
#include <cstdio> #include <cstring> #include <algorithm> using namespace std; typedef long long ll; ll SG (ll x) { return x&1 ? SG(x>>1) : x>>1; } int main () { int cas, n; scanf("%d", &cas); while (cas--) { ll m, v = 0; scanf("%d", &n); for (int i = 0; i < n; i++) { scanf("%lld", &m); v ^= SG(m); } printf("%s\n", v ? "YES" : "NO"); } return 0; }
相关文章推荐
- uvalive 5059 Playing With Stones(组合游戏,SG函数)@
- UVA 1482 - Playing With Stones(SG打表规律)
- UVA 1482 - Playing With Stones(SG打表规律)
- UVA 1482 - Playing With Stones (SG博弈)
- UVA - 1482 Playing With Stones
- Nim游戏的一个扩展——51nod 1661 黑板上的游戏+LA 5059 Playing With Stones
- UVA1482:Playing With Stones(SG)
- UVa 11859 除法游戏(Nim游戏,质因子)
- uva 1482 - Playing With Stones
- UVA 11859 - Division Game(Nim游戏)
- UVA 11859 - Division Game(Nim游戏)
- NIM(1) 一排石头的游戏
- 组合数学——Nim取子游戏
- HDOJ S-Nim 1536&POJ S-Nim 2960【求SG函数+Nim游戏】
- [POJ2975] Nim(Nim游戏,博弈)
- BZOJ.1022.[SHOI2008]小约翰的游戏John(博弈论 Anti-Nim)
- 例题7-12 UVA - 1343 The Rotation Game 旋转游戏(IDA*)
- uva1343 旋转游戏
- ICG游戏博弈一________nim游戏模型
- 一道面试题(Nim取子游戏)——如何将数学思维应用到编程中