nim游戏解法(转)
转自:http://acm.hdu.edu.cn/forum/read.php?fid=9&tid=10617
- 取火柴的游戏
- 题目1:今有若干堆火柴,两人依次从中拿取,规定每次只能从一堆中取若干根,
- 可将一堆全取走,但不可不取,最后取完者为胜,求必胜的方法。
- 题目2:今有若干堆火柴,两人依次从中拿取,规定每次只能从一堆中取若干根,
- 可将一堆全取走,但不可不取,最后取完者为负,求必胜的方法。
- 先解决第一个问题吧。
- 定义:若所有火柴数异或为0,则该状态被称为利他态,用字母T表示;否则,
- 为利己态,用S表示。
- [定理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态。证毕
- [定理2]:T态,取任何一堆的若干根,都将成为S态。
- 证明:用反证法试试。
- 若
- c = A(1) xor A(2) xor … xor A(i) xor … xor A(n) = 0;
- c' = A(1) xor A(2) xor … xor A(i') xor c xor … xor A(n) = 0;
- 则有
- c xor c' = A(1) xor A(2) xor … xor A(i) xor … xor A(n) xor A(1) xor A(2) xor … xor A(i') xor c xor … xor A(n) = A(i) xor A(i') =0
- 进而推出A(i) = A(i'),这与已知矛盾。所以命题得证。
- [定理 3]:S态,只要方法正确,必赢。
- 最终胜利即由S态转变为T态,任何一个S态,只要把它变为T态,(由定理1,可以把它变成T态。)对方只能把T态转变为S态(定理2)。这样,所有S态向T态的转变都可以有己方控制,对方只能被动地实现由T态转变为S态。故S态必赢。
- [定理4]:T态,只要对方法正确,必败。
- 由定理3易得。
- 接着来解决第二个问题。
- 定义:若一堆中仅有1根火柴,则被称为孤单堆。若大于1根,则称为充裕堆。
- 定义:T态中,若充裕堆的堆数大于等于2,则称为完全利他态,用T2表示;若充裕堆的堆数等于0,则称为部分利他态,用T0表示。
- 孤单堆的根数异或只会影响二进制的最后一位,但充裕堆会影响高位(非最后一位)。一个充裕堆,高位必有一位不为0,则所有根数异或不为0。故不会是T态。
- [定理5]:S0态,即仅有奇数个孤单堆,必败。T0态必胜。
- 证明:
- S0态,其实就是每次只能取一根。每次第奇数根都由己取,第偶数根都由对
- 方取,所以最后一根必己取。败。同理, T0态必胜#
- [定理6]:S1态,只要方法正确,必胜。
- 证明:
- 若此时孤单堆堆数为奇数,把充裕堆取完;否则,取成一根。这样,就变成奇数个孤单堆,由对方取。由定理5,对方必输。己必胜。 #
- [定理7]:S2态不可转一次变为T0态。
- 证明:
- 充裕堆数不可能一次由2变为0。得证。 #
- [定理8]:S2态可一次转变为T2态。
- 证明:
- 由定理1,S态可转变为T态,态可一次转变为T态,又由定理6,S2态不可转一次变为T0态,所以转变的T态为T2态。 #
- [定理9]:T2态,只能转变为S2态或S1态。
- 证明:
- 由定理2,T态必然变为S态。由于充裕堆数不可能一次由2变为0,所以此时的S态不可能为S0态。命题得证。
- [定理10]:S2态,只要方法正确,必胜.
- 证明:
- 方法如下:
- 1) S2态,就把它变为T2态。(由定理8)
- 2) 对方只能T2转变成S2态或S1态(定理9)
- 若转变为S2, 转向1)
- 若转变为S1, 这己必胜。(定理5)
- [定理11]:T2态必输。
- 证明:同10。
- 综上所述,必输态有: T2,S0
- 必胜态: S2,S1,T0.
- 两题比较:
- 第一题的全过程其实如下:
- S2->T2->S2->T2-> …… ->T2->S1->T0->S0->T0->……->S0->T0(全0)
- 第二题的全过程其实如下:
- S2->T2->S2->T2-> …… ->T2->S1->S0->T0->S0->……->S0->T0(全0)
- 下划线表示胜利一方的取法。 是否发现了他们的惊人相似之处。
- 我们不难发现(见加黑部分),S1态可以转变为S0态(第二题做法),也可以转变为
- T0(第一题做法)。哪一方控制了S1态,他即可以有办法使自己得到最后一根(转变为
- T0),也可以使对方得到最后一根(转变为S0)。
- 所以,抢夺S1是制胜的关键!
- 为此,始终把T2态让给对方,将使对方处于被动状态,他早晚将把状态变为S1.
nim游戏解法(转)的更多相关文章
- Nim积解法小结
由于某毒瘤出题人 redbag 不得不学习一下这个史诗毒瘤算法. 本文参考了 Owaski 的 GameTheory 的课件. 定义 我们对于一些二维 \(\mathrm{Nim}\) 游戏(好像更高 ...
- 【博弈论】Nim游戏
百度百科 Definition 这样的游戏被称为Nim游戏: 1.有两个玩家,轮流进行操作 2.是公平游戏.即面对同一局面两个玩家所能进行的操作是相同的.例如中国象棋不是公平游戏.因为面对同一个局面, ...
- NIM游戏,NIM游戏变形,威佐夫博弈以及巴什博奕总结
NIM游戏,NIM游戏变形,威佐夫博弈以及巴什博奕总结 经典NIM游戏: 一共有N堆石子,编号1..n,第i堆中有个a[i]个石子. 每一次操作Alice和Bob可以从任意一堆石子中取出任意数量的石子 ...
- 石子游戏(nim游戏+按位考虑)
题意 给\(n\)堆石子,每次最多可以从一堆中取\(x\)个,问你\(x = 1 ... n\)时的答案. 解法 经典\(nim\)游戏,找规律知\(sg[i] = i \ mod \ (x+1)\) ...
- Nim游戏
目前有3堆石子,每堆石子个数也是任意的,双方轮流从中取出石子,规则如下:1)每一步应取走至少一枚石子:每一步只能从某一堆中取走部分或全部石子:2)如果谁不能取谁就失败. Bouton定理: 必败状态当 ...
- BZOJ 3105 [CQOI2013]新Nim游戏 ——线性基
[题目分析] 神奇的题目,两人都可以第一次取走足够多堆的石子. nim游戏的规则是,如果异或和为0,那么就先手必输,否则先手有必胜策略. 所以只需要剩下一群异或和为0就可以了. 先排序,线性基扫一遍即 ...
- 【BZOJ-2460&3105】元素&新Nim游戏 动态维护线性基 + 贪心
3105: [cqoi2013]新Nim游戏 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 839 Solved: 490[Submit][Stat ...
- 【BZOJ】3105: [cqoi2013]新Nim游戏
http://www.lydsy.com/JudgeOnline/problem.php?id=3105 题意:k堆火柴,先手和后手在第一次拿的时候都能拿若干整堆火柴(但不能拿完),之后和nim游戏规 ...
- BZOJ3105: [cqoi2013]新Nim游戏 博弈论+线性基
一个原来写的题. 既然最后是nim游戏,且玩家是先手,则希望第二回合结束后是一个异或和不为0的局面,这样才能必胜. 所以思考一下我们要在第一回合留下线性基 然后就是求线性基,因为要取走的最少,所以排一 ...
随机推荐
- 【Codeforces 158B】Taxi
[链接] 我是链接,点我呀:) [题意] 每辆车可以载重4个人. 一共有n个组,每个组分别有s[i]个人. 要求每个组的人都在同一辆车里面. 问最少需要多少辆车 [题解] 将每个组的人数从小到大排序. ...
- Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Invocation of init method fail
SpringBoot 单元测试报错 @RunWith(SpringRunner.class) @SpringBootTest public class ProductCategoryRepositor ...
- PowerDesigner16.5 使用遇到的问题
目录 1.PowerDesigner 菜单栏中没有 Datebase 2.PowerDesigner连接远程mysql数据库连接不上 3.怎样去掉窗口中的黑色网格线 4.设置默认"不为空&q ...
- Markdown 基本使用
My First Markdown 标签(空格分隔): 未分类 # Markdown 11种基本语法## 设置标题在此输入正文标题设置(让字体变大,和word的标题意思一样)在Markdown当中设置 ...
- hdu_1014_Uniform Generator_201310141958
Uniform Generator Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- cogs 2478. [HZOI 2016]简单的最近公共祖先
2478. [HZOI 2016]简单的最近公共祖先 ★☆ 输入文件:easy_LCA.in 输出文件:easy_LCA.out 简单对比时间限制:2 s 内存限制:128 MB [题 ...
- window.parent与window.opener、window.showModalDialog的区别 opener和showModalDialog刷新父页面的方法
项目中使用案例: 父窗体 <s:form namespace="/forexagent" id="listSearchForm" name="t ...
- install pip 回顾
在install pip的时候遇到如下问题 1. yum install 想安装一个package 总是提示没有package 可以安装. 但是后来可以了 2. make 和 configure 到底 ...
- SQLServer到底支持多少连接数的并发?
1)不启用连接池 当创建到101个连接的时候,就无法再创建新连接了.也就是说,如果连接字符串不做任何处理,我们的程序只能够跟SQLServer建立101个连接. 2)启用连接池 在连接字符串中加入代码 ...
- MVC.Net5:添加Tinymce的图片上传功能
Tinymce是目前几个主流的Web文本编辑器之一,不过它的图片上传功能是要收费的,而其它几个免费的上传图片的插件支持的都是PHP.那么就只能自己动手写一个了(源代码下载). 准备工作如下:1. ...