$NIM$游戏小总结
$umm$可能之后会写个博弈论总结然后就直接把这个复制粘贴上去就把这个删了
但因为还没学完所以先随便写个$NIM$游戏总结趴$QAQ$
首先最基础的$NIM$游戏:有$n$堆石子,每次可以从一堆中取若干个,求最后谁胜利
这种有个结论,是说当开局所有数异或起来不为0时先手必胜
证明在这里写了下,懒得再写遍了挺显然的$QwQ$
(大概$get$了一下$SG$函数之后来瞎$upd$下,,,
就,这儿其实是可以用$SG$函数解释的
简单来说,不难得到$SG(x)=x$,挺显然的?就,因为可以取任意多个,于是有$SG(x)=mex(SG(x-1),SG(x-2),...,SG(0))$,数学归纳法即可$QwQ$
又有$SG(G)=SG(x_{1})$^$SG(x_{2})$^$...$,于是就有当$x_{1}$^$x_{2}$^...^$x_{n}\neq 0$时先手必胜,否则必败
然后说下变式昂
变式1:每次取的石子数量有上界$m$
$umm$就是一个$bash\ game$+$NIM\ game$(关于$bash\ game$的话放个最$easy$的入门题趴$QwQ$
直接把所有值对$m+1$取膜就好,证明十分显然?就一定能在先手/后手的操纵下就像$bash-game$中一样使得每堆石子的数量都<=$m$,这时候就相当于没有这个$m$的限制了就当普通$NIM$游戏做就好了$QwQ$
变式2:每次可以从$k$堆中取若干个
基础$NIM$游戏可以当做是这个变式的一个$easy$版情况?就相当于是$NIM_{1}$嘛
那就考虑能不能用一点儿,类比的思想,从类似的角度考虑这个问题的通解$QwQ$?
于是不难得出结论所有数在$k$进制下做不进位加法不为0时先手必胜
再来瞎证下趴$QAQ$
按之前证$NIM$游戏结论时候的流程,依然是考虑当在$k$进制下做不进位加法不为0时的情况,考虑如果能取一些石子使得变为在$k$进制下做不进位加法为0
这时又是两种情况
第一种是没有石子剩余了,欧克赢了,不说
第二种是还有石子剩余,因为最多只能从$k$堆中拿,所以不可能出现后手拿了之后依然是$k$进制下做不进位加法答案是0的情况,即一定又能回到最开始
那就相当于现在只要能证,在不进位加法不为0的情况下能取出一些石子使它变为等于0的状态就好
考虑对所有数字都$k$进制分解,开个数组$a_{i,j}$,表示第$j$个数在$k^{i}$下的取值,再开个$sum_{i}$表示$\sum a_i\ mod\ k$,显然对每一位$i$,取出$sum_{i}$就好
显然是可以达成的
证毕!(好像表述不太清,,,算了不管了$TT$
变式3:阶梯博弈
先说下这类题是啥$QwQ$
大概就是有个高度递增的楼梯,每一级上都有若干个球,每次操作可以选择一级楼梯,选择上面的若干个球移动到边上更低的那一极去,当移动到地面(第0级楼梯)的时候就不能操作了
这题也是有个结论,是说可以忽略偶数级台阶,剩余的奇数级构成的$NIM$游戏的结果就是这个题的结果
知道结论了的话证明还是不难的$QwQ$,下面瞎证下趴$QAQ$
首先当所有球都到0级楼梯时就不能移动了,是在偶数级楼梯上的
然后当对方移动了偶数级楼梯的时候,比如将$d$个球从第$2n$级到了第$2n-1$级,就把第$2n-1$级上的$d$个球移到第$2n-2$级去
这样就可以保证,从奇数移至偶数,相当于是拿走,从偶数移至奇数,相当于没有意义
如果能$get$这点的话也就不难想到只考虑奇数层的时候就是个普通的$NIM$游戏了呢$QwQ$
例题:
[X]$poj1704$
随机推荐
- 深度解读Helm 3: 犹抱琵琶半遮面
自去年年初开始放风Helm v3将要开始开发,到去年年底KubeConn 上海被一堆人追问到底啥时候发版本.今年五月份,Helm v3 终于发布了第一个alpha版本,让我们来一窥新版本的Helm 到 ...
- CSS检测窗口大小显示和隐藏内容
代码不多 用css写的话简单一点 @media (max-width: 1024px) { #hidden { display: none; } } max-width 是要检测的宽度
- hdu 1286 找新朋友 (容斥原理 || 欧拉函数)
Problem - 1286 用容斥原理做的代码: #include <cstdio> #include <iostream> #include <algorithm&g ...
- vector容器、
一. vector 向量容器1. 创建 vector 对象(1)不指定容器大小vector<int> V;(2)指定容器大小vector<int> V(10);(3) ...
- 2018-8-10-使用-RetroShare-分享资源
title author date CreateTime categories 使用 RetroShare 分享资源 lindexi 2018-08-10 19:16:51 +0800 2018-02 ...
- 试用ZooKeeper
ZooKeeper下载 通过ZooKeeper官网下载最新的稳定版本 解压ZooKeeper到某个目录,其目录结构为: 运行环境要求 系统环境 ZooKeeper对于市面上各种操作系统都有了不错的支持 ...
- 浅谈集合框架四——集合扩展:集合循环输出方式及list输出方式的效率对比
最近刚学完集合框架,想把自己的一些学习笔记与想法整理一下,所以本篇博客或许会有一些内容写的不严谨或者不正确,还请大神指出.初学者对于本篇博客只建议作为参考,欢迎留言共同学习. 之前有介绍集合框架的体系 ...
- 解析PHP跳出循环的方法以及continue、break、exit的区别介绍
本篇文章是对PHP跳出循环的方法以及continue.break.exit的区别进行了详细的分析介绍,需要的朋友参考下 PHP中的循环结构大致有for循环,while循环,do{} while 循 ...
- win2d 通过 CanvasActiveLayer 画出透明度和裁剪
本文告诉大家如果在 UWP 的 win2d 通过 CanvasActiveLayer 创建一层,在这里画出的图片有透明度或者裁剪 在 win2d 如果需要对某个元素裁剪,可以使用很多方法,本文只是告诉 ...
- D3.js力导向图中新增节点及新增关系连线示例
大家在使用D3.js中的力导向图时,基本都会遇到动态增加节点及连线的需求,这里记录一下我的实现方式. 话不多说,先放代码: <!DOCTYPE html> <html lang=&q ...