一个蒟蒻来口胡$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函数的更多相关文章

  1. 简单易懂的博弈论讲解(巴什博弈、尼姆博弈、威佐夫博弈、斐波那契博弈、SG定理)

    博弈论入门: 巴什博弈: 两个顶尖聪明的人在玩游戏,有一堆$n$个石子,每次每个人能取$[1,m]$个石子,不能拿的人输,请问先手与后手谁必败? 我们分类讨论一下这个问题: 当$n\le m$时,这时 ...

  2. SG函数和SG定理【详解】

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  3. SG函数&&SG定理

    必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点,处于此情况下,双方操作均正确的情况下必胜. 必胜点和必败点的 ...

  4. (转载)--SG函数和SG定理【详解】

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  5. 组合游戏 - SG函数和SG定理

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  6. SG函数和SG定理(Sprague_Grundy)

    一.必胜点和必败点的概念 P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.       N点:必胜点,处于此情况下,双方操作均正确的情况下必胜. 必胜点和必败点的性质:     ...

  7. HDU 1851 (巴什博奕 SG定理) A Simple Game

    这是由n个巴什博奕的游戏合成的组合游戏. 对于一个有m个石子,每次至多取l个的巴什博奕,这个状态的SG函数值为m % (l + 1). 然后根据SG定理,合成游戏的SG函数就是各个子游戏SG函数值的异 ...

  8. HDU5795A Simple Nim SG定理

    A Simple Nim Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tota ...

  9. HDU5724 Chess(SG定理)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5724 Description Alice and Bob are playing a spe ...

随机推荐

  1. 解决 CentOS 7 添加用户设置家目录出现 useradd cannot set SELinux context for home directory 问题

    问题描述 直接贴下代码吧~ [root@localhost ~]# useradd -d /tmp/heheda4 heheda4 useradd: cannot set SELinux contex ...

  2. AForge.net简介和认识

    AForge.NET是一个专门为开发者和研究者基于C#框架设计的,他包括计算机视觉与人工智能,图像处理,神经网络,遗传算法,机器学习,模糊系统,机器人控制等领域.这个框架由一系列的类库组成.主要包括有 ...

  3. WOJ1019 所有的M数

    题目链接: WOJ1019 题目分析: 单调栈维护,读一个进来,如果前面的比它大就弹出来,然后压栈里(反正它在最右边) 压进栈里输出它前面那个数就好了 O(n)扫一遍就能过 真的水得不能再水的题了-- ...

  4. 线段树/树状数组 POJ 2182 Lost Cows

    题目传送门 题意:n头牛,1~n的id给它们乱序编号,已知每头牛前面有多少头牛的编号是比它小的,求原来乱序的编号 分析:从后往前考虑,最后一头牛a[i] = 0,那么它的编号为第a[i] + 1编号: ...

  5. Angular4项目,默认的package.json创建及配置

        1.使用如下命令,可以创建一个默认的 package.json npm  init     创建后如下图所示: 添加 angular4 的 dependencies: npm install@ ...

  6. python关于文件的一些记录

    1.文件打开: file("data.txt")或open("data.txt")注意不要漏了文件的后缀.(不加参数时,file为你默认为'r',reading ...

  7. RHEL 6.5----iscsi多路径存储

    主机名 IP master eth0: 192.168.30.130(NAT) eth1: 192.168.17.130(VMNet4) node-1 eth0: 192.168.30.131(NAT ...

  8. SAMBA服务初学练习

    服务概述 Samba最先在Linux和Windows之间架起了一座桥梁,正是由于Samba的出现,我们可以在Linux和Windows之间实现文件共享的相互通讯,我们可以将其架设成一个功能非常强大的文 ...

  9. AJPFX分享eclipse自动生成java注释方法

    设置方法介绍:eclipse中:Windows->Preferences->Java->Code Style->Code Template->Comments,然后对应的 ...

  10. 备忘录模式及php实现

    备忘录模式: 又叫做快照模式或Token模式,在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. 角色: 1.创建者:负责创建一个备忘 ...