第1章 游戏之乐——NIM(1)一排石子的游戏
NIM(1)一排石子的游戏
转载:编程之美-MIN(1)一排石头的游戏
1. 原题
1.1 题目
N块石头排成一行,每块石头有各自固定的位置。两个玩家依次取石头,每个玩家每次可以取其中任意一块石头,或者相邻的两块石头,石头在游戏过程中不能移位(即编号不会改变),最后能将剩下的石头一次取光的玩家获胜。这个游戏有必胜策略吗?
1.2 解答
已知:石头数量为N,假设两个玩家分别为玩家A和玩家B,且玩家A先取石头。
当N<=2时,玩家A可以直接取完所有的石头,玩家A有必胜策略。
当N=3时,玩家A先取中间的1个石头,剩下的两个石头,玩家B只能取其中的1个,最后1个由玩家A取得,玩家A有必胜策略。
当N=4时,玩家A先取中间的2个石头,这会又剩下2个石头,玩家B还是只能取其中1个,最后一个由玩家A取得,玩家A有必胜策略。
当N>4,且N为奇数时,玩家A取中间的1个石头,剩下的左边石头情况和右边石头情况一样,那么无论玩家B如何取石头,玩家A只要
在相反的方向取相同数量的石头即可,如此下去,最后必然玩家A取得最后的石头,A有必胜策略。
根据上面的归纳,先手的玩家只有把中间的石头拿走,如果N是奇数,就拿走中间的1个石头,如果N是偶数,就拿走中间的2个石头,
这样留给玩家B一个对称的局面,接着,无论玩家B怎么拿石头,玩家A都保证对称局面不变,这样,最后肯定是A取得最后的石头。
2. 扩展1
2.1 题目
若规定最后取光石头的人输,又该如何应对?
2.2 解答
N=1时,A必须取得这唯一的也是最后的一个石头,A必然输掉,这是必然结果,无需策略。
N=2时,A取一个石头,那么B必然取得剩下的一个石头,A有必胜策略。
N=3时,A取两个石头,那么B必然取得剩下的一个石头,A有必胜策略。
N=4时,若A取两个石头,那么B取一个石头,A只能取最后剩下的一个石头。
若A取一个石头,那么B取两个石头,A只能取最后剩下的一个石头。
因此,无论A怎么取,B都有必胜策略。
N=5时,A只需取边上的一个石头,这样就转化为N=4,B先取了,这样根据上面的分析,可知N=4时,后取的有必胜策略,
因此,A有必胜策略。
N=6时,A只需取边上的两个石头,这样就转化为N=4,B先取了,这样根据上面的分析,可知N=4时,后取的有必胜策略,
因此,A有必胜策略。
从上面可以看出,从3开始A的胜负交替出现,以后的每个问题都可以转化为上一个的子问题,因此N>=3时当N为奇数时A有必胜策略,当N为偶数时B有必胜策略。
感觉这个扩展中比较麻烦的地方在于“一排石子”,而且N很大的情况下,如果一步一步A和B分别取石子后,最后得到的石子之间可能不是连续的,这样结果就不确定了。比如:最后还有3个连续的石子,A先取,A有必胜策略;最后还有3个都不连续的石子,A先取,A肯定失败。所以呢,最后剩余的石头状态很重要,现在我只是分析到这里,也没看到网上谁很好的解决了这个问题。
3. 扩展2
3.1 题目
若两个人轮流取一堆石头,每人每次最少取1块石头,最多取K块石头,最后取光石头的人赢得此游戏。
3.2 解答
1)极端情况:K>=N
玩家A可以直接取掉所有石头,获得胜利。
2) 一般情况:K<N
这里面有个规律,就是,无论一个玩家拿了多少个石头,另一个玩家都能够选择相应的石头数量,使得两个玩家一起拿K+1个石头。
从上面这个思路,我们考虑N与K+1之间的数值关系:
N = (K+1) * c + d,其中c>=1,d>=0
当d!=0时,玩家A先取d个石头,这样还剩(K+1)*c个石头。然后轮到玩家B取石头,不管玩家B取了多少个石头,玩家A都再取相应
的石头,使得玩家A和玩家B一起取(K+1)个石头,这样,还剩(K+1)*(c-1)个石头,如此往复,最后,肯定A取完石头。
举例说明:
剩余石头数目 取石头
(K+1) * c + d A取d个
(K+1) * c B取X个,A取(K+1-X)个
(K+1) * (c-1) ...
K+1 B取X个A取(K+1-X)个
0
当d=0时,无论A取多少个石头,B取相应的石头,使得A和B一起取(K+1)个石头,这样最后取到石头的肯定是玩家B。
举例说明:
剩余石头数目 取石头
(K+1) * c A取X个,B取(K+1-X)个
(K+1) * (c-1) ...
... ...
K+1 A取X个,B取(K+1-X)个
0
即N%(K+1)==0时,玩家B有必胜策略,N%(K+1)!=0时,玩家A有必胜策略。
可以看出来,如果K很大的话,而N的数值是随机的话,先手的优势是很明显的。
第1章 游戏之乐——NIM(1)一排石子的游戏的更多相关文章
- 第1章 游戏之乐——NIM(2)“拈”游戏分析
NIM(2)“拈”游戏分析 1. 问题 有N块石头和两个玩家A和B,玩家A先将石头分成若干堆,然后按照BABA……的顺序不断轮流取石头,能将剩下的石头一次取光的玩家获胜.每次取石头时,每个玩家只能从若 ...
- 第1章 游戏之乐——NIM(3)两堆石头的游戏
NIM(3)两堆石头的游戏 1. 问题描述 假设有两堆石头,有两个玩家会根据如下的规则轮流取石头:每人每次可以从两堆石头中各取出数量相等的石头,或者仅从一堆石头中取出任意数量的石头:最后把剩下的石头一 ...
- NIM(1) 一排石头的游戏
最近在实习面试过程中,一个朋友遇到了该问题,从简单到复杂的思路如下,希望能给遇到相同问题的朋友一些启发和帮助.(内容来源网络和<编程之美>) 1.问题1 100个苹果 桌上有100个苹果, ...
- [ACM_数学] Fibonacci Nim(另类取石子,2-4组合游戏)
游戏规则: 有一堆个数为n的石子,游戏双方轮流取石子,满足: 1)先手不能在第一次把所有的石子取完: 2)之后每次可以取的石子数介于1到对手刚取的石子数的2倍之间(包含1和对手刚取的石子数的2倍). ...
- (linux shell)第二章--命令之乐(一)
文章来自于我的个人博客:(linux shell)第二章--命令之乐(一) 上一章我们描写叙述了一些linux shell中须要注意的一些语法.接下来我们開始了解linux shell的经常使用 ...
- Poj 1067 取石子游戏(NIM,威佐夫博奕)
一.Description 有两堆石子,数量任意,可以不同.游戏开始由两个人轮流取石子.游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子:二是可以在两堆中同时取走相同数量的石子. ...
- NIM游戏,NIM游戏变形,威佐夫博弈以及巴什博奕总结
NIM游戏,NIM游戏变形,威佐夫博弈以及巴什博奕总结 经典NIM游戏: 一共有N堆石子,编号1..n,第i堆中有个a[i]个石子. 每一次操作Alice和Bob可以从任意一堆石子中取出任意数量的石子 ...
- 【读书笔记《Android游戏编程之从零开始》】16.游戏开发基础(动画)
1. Animation动画 在Android 中,系统提供了动画类 Animation ,其中又分为四种动画效果: ● AlphaAnimation:透明度渐变动画 ● ScaleAnimati ...
- 【读书笔记《Android游戏编程之从零开始》】15.游戏开发基础(剪切区域)
剪切区域也称为可视区域,是由画布进行设置的:它指的是在画布上设置一块区域,当画布一旦设置了可视区域,那么除此区域外,绘制的任何内容都将看不到:可视区域可以是圆形.矩形等等. 画布提供了三种设置可视区域 ...
随机推荐
- SSH 连接慢的解决方案详解
SSH 连接慢的解决方案详解 http://www.codeceo.com/article/ssh-slow.html
- 《Python 学习手册4th》 第十七章 作用域
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...
- cadence异型孔
1:画route path的边框,画在board geometry的ncroute_path层上,可以用zcopy (暂时没用过) 没有的话可能:WARNING: No route path ...
- AWR
Automatic Workload Repository是10g引入的一个重要组件.在里面存贮着近期一段时间内,默认是7天,数据库活动状态的详细信息 手动得到一份AWR报告: SQL> exe ...
- RPC框架motan: 通信框架netty之Netty4Client
上文已经初步探讨了如何实现一个具体的transport,本文就来讨论一个具体的transport,本文讨论netty4的的相关实现.老规矩,看看motan-transport的目录结构. 其中最重要的 ...
- Apache:如何利用.htaccess文件对PHP网站或文件进行伪静态处理
来源:http://www.ido321.com/1123.html 今天get了一招:利用.htaccess文件对PHP网站或文件进行伪静态处理. 一.检查服务器是否支持伪静态处理: 必 须要空间支 ...
- iOS完结篇
从去年自己陆陆续续接触iOS开发,几个月过去了,对于苹果的体验,流程,以及规范都有了一定的认 识,还会定期关注iOS的发展. 即将要做win10系统了,为了纪念把自己的虚拟机截图留念吧.也希望微软能在 ...
- 《Java数据结构与算法》笔记-CH4-2用栈实现字符串反转
import java.io.BufferedReader; import java.io.InputStreamReader; //用栈来实现一个字符串逆序算法 /** * 数据结构:栈 */ cl ...
- Codeforces 377
简单说一下. A 搜索出任意一个剩余细胞个数的联通块.剩下的填X. B 二分加贪心加数据结构. /* * Problem: * Author: Shun Yao */ #include <str ...
- 第二百四十六天 how can I 坚持
领悟啊.好伤心啊. 到底应该是怎样的一个过程,才能得到想要的结果啊. 我不懂我自己.. 睡觉吧. 中午吃的米线. 好渴,晚上没喝水呢,活该.谁让你一直玩游戏. 睡觉了.弟弟回家了,过两天去烟台待一个月 ...