SG定理与SG函数
一个蒟蒻来口胡$SG$函数与$SG$定理。
要是发现有不对之处望指教。
首先我们来了解一下$Nim$游戏。
$Nim$游戏是公平组合游戏的一种,意思是当前可行操作仅依赖于当前局势。
而经典$Nim$游戏是指,一个地方放了$n$堆棋子,每堆棋子数目$a_i$给定。
两人轮流操作,每次操作从一堆中拿出任意数量的棋子。即最少拿一个,最多拿完。
拿完棋子的人胜。
如果两人都执行最优决策的话,胜负在刚开局时就已经确定了。
而在最有决策下,$Nim$游戏的胜负计算方式是:
若每堆棋子数量a_1^a_2^a_3^……^a_n=0则先手负,反之先手胜。
好像很玄学,怎么证明?
假设开局时a_1^a_2^a_3^……^a_n=0,
先手取走其中一堆的一些棋子,假设在$a_1$中去,那么式子变为a_1^a_2^a_3^……^a_n=k且$k!=0$。
此时一定存在一个$a_i$,满足二进制下$a_i$在$k$的最高位为$1$。
此时只要将$a_i$变为a_i ^ k,那么这$n$个数的异或和依然为$0$。
比如,原来集合中有{2,4,6},满足2^4^6=0;
先手拿走了6的一整堆,此时2^4^0=6;
而4与6满足性质,此时只需要让4变为4^6=2即可。
先手后手一直在拿走棋子,使得总数一直在减小,减小到的终点即0^0^0^……^0=0。
就一定是后手胜啦。
后来出题人们搞出了好多类似$Nim$游戏的博弈问题,而归根结底处理方法依然可以用异或法。
这就又衍生出了$SG$函数和$SG$定理。
先定义一下$mex$运算。
$mex$指对于一个非负整数集合不在其中的最小数。
举个例子,mex{}=0,mex{0,1,2,3}=4,mex{1,2,3,4,5}=0。
回到$SG$函数。
对于一个局势,不同的操作会产生不同的后果,产生不同的新局势。
当前局势的$SG$函数值,等于所有后继局势的$SG$函数的$mex$值。
比如说,当$Nim$游戏中只有一堆棋子时,对于每个棋子数$SG$函数计算如下:
SG[0]=mex{}=0
SG[1]=mex{0}=1
SG[2]=mex{0,1}=2
SG[3]=mex{0,1,2}=3
等等。
有什么用呢?
一个局势是$P-position$(先手必败)当且仅当其$SG$函数值为$0$。
哇好厉害啊。
接下来上$SG$定理:
对于任意有限多个公平组合游戏的组合,其$SG$函数值等于所有子游戏$SG$函数值的异或和。
能不能理解为,第一个游戏有好几堆棋子,第二个游戏有好几堆棋子……
结果整个游戏就是好几堆棋子,其$SG$函数等于所有堆的$SG$函数的异或和。
大概
就这些了。
模板靠手速,博弈靠智商
(o_o)
SG定理与SG函数的更多相关文章
- 简单易懂的博弈论讲解(巴什博弈、尼姆博弈、威佐夫博弈、斐波那契博弈、SG定理)
博弈论入门: 巴什博弈: 两个顶尖聪明的人在玩游戏,有一堆$n$个石子,每次每个人能取$[1,m]$个石子,不能拿的人输,请问先手与后手谁必败? 我们分类讨论一下这个问题: 当$n\le m$时,这时 ...
- SG函数和SG定理【详解】
在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念: P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点 ...
- SG函数&&SG定理
必胜点和必败点的概念: P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点,处于此情况下,双方操作均正确的情况下必胜. 必胜点和必败点的 ...
- (转载)--SG函数和SG定理【详解】
在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念: P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点 ...
- 组合游戏 - SG函数和SG定理
在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念: P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点 ...
- SG函数和SG定理(Sprague_Grundy)
一.必胜点和必败点的概念 P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点,处于此情况下,双方操作均正确的情况下必胜. 必胜点和必败点的性质: ...
- HDU 1851 (巴什博奕 SG定理) A Simple Game
这是由n个巴什博奕的游戏合成的组合游戏. 对于一个有m个石子,每次至多取l个的巴什博奕,这个状态的SG函数值为m % (l + 1). 然后根据SG定理,合成游戏的SG函数就是各个子游戏SG函数值的异 ...
- HDU5795A Simple Nim SG定理
A Simple Nim Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tota ...
- HDU5724 Chess(SG定理)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5724 Description Alice and Bob are playing a spe ...
随机推荐
- python 类装饰器
class Test(): def __init__(self, func): print('装饰器1') self.__func = func def __call__(self): print(' ...
- pycharm 激活码激活
http://idea.lanyus.com/ 去这个网站获取激活码,输入即可,亲测可用
- 2018 年度码云热门项目排行榜 TOP 10
2016 年度码云热门项目排行榜 TOP 10 是通过开源项目2016年在码云上的 Watch.Star.Fork 数量来评定的榜单.码云平台发展至今,涌现了越来越多优秀的开源项目,越来越多的开源作者 ...
- Jmeter之添加响应断言,bean shell post processor
一直在想运用jmeter来实现接口自动化测试,但是每次每个接口执行完,需要肉眼去看一看,执行的结果对不对,总结了两种办法, 一.将每个请求的响应结果,导出到文件 选中请求右键-->添加后置处理器 ...
- [WOJ1138]最大子序和
题目链接: WOJ1138 题目分析: 是很经典的一道题,乱搞的方法应该有不少,这里介绍O(n)的单调队列做法 首先维护一个前缀和,然后枚举每一个位置,维护一个前缀和单增的单调队列,但队列仅储存下标, ...
- DFS水题 URAL 1152 False Mirrors
题目传送门 /* 题意:一个圈,每个点有怪兽,每一次射击能消灭它左右和自己,剩余的每只怪兽攻击 搜索水题:sum记录剩余的攻击总和,tot记录承受的伤害,当伤害超过ans时,结束,算是剪枝吧 回溯写挫 ...
- rhel7使用centos7yum组件
1)rpm -qa|grep yum --查看已安装的yum组件包 2)rpm -e 包名 --nodeps --卸载包 3)下载安装以下组件包: 使用rpm -ivh yum-* yum-3.4.3 ...
- 浅议block实现原理,block为什么使用copy关键字?
1.block是一个特殊的oc对象,建立在栈上,而不是堆上,这么做一个是为性能考虑,还有就是方便访问局部变量. 2.默认Block使用到的局部变量会被copy,而不是retain.所以,他无法改变局部 ...
- SpringBoot 2.x (7):拦截器
类似以前SpringMVC的拦截器,但也有一些区别 SpringBoot的拦截器有两种方式: 第一种方式:过时的方式,适用于SpringBoot1.x的方式 package org.dreamtech ...
- 【转】一个Java对象到底占多大内存?
最近在读<深入理解Java虚拟机>,对Java对象的内存布局有了进一步的认识,于是脑子里自然而然就有一个很普通的问题,就是一个Java对象到底占用多大内存? 在网上搜到了一篇博客讲的非常好 ...