从Nim游戏到SG函数

从Nim游戏到SG函数

Nim游戏

公平组合问题在蓝桥杯等算法竞赛中经常出现,最经典的例子莫过于Nim游戏

Nim游戏:两个玩家面前有若干堆石子,每个玩家每次可在每堆石子中取走任意多个石子,取走最后一枚石子的玩家获胜。

其结论为如果所有堆的石子个数的异或值为0,那么代表这个状态是先手必负,否则说明该状态为先手必胜状态。

SG函数

由SG定理可知,所有的公平组合问题都等价于若干单堆Nim游戏的和(要求是类似取走最后一个石子的人获胜)

例子

Bash博弈

一堆石子,每次只能取1~k个,取到最后一个石子的人获胜。

首先SG(0)=0为先手必负状态

SG(1)=1

SG(2)=2

SG(3)=3

...

SG(k)=k

SG(k+1)=0

因此Bash博弈的先手必负条件等价于n%(k+1)=0

否则先手必胜.

相关推荐
小江的记录本43 分钟前
【分布式】分布式核心组件——分布式ID生成:雪花算法、号段模式、美团Leaf、百度UidGenerator、时钟回拨解决方案
分布式·后端·算法·缓存·性能优化·架构·系统架构
大江东去浪淘尽千古风流人物2 小时前
【cuVSLAM】GPU 加速、多相机、实时视觉/视觉惯性 SLAM设计优势
c++·人工智能·数码相机·ubuntu·计算机视觉·augmented reality
自信150413057597 小时前
重生之从0开始学习c++之模板初级
c++·学习
leobertlan7 小时前
好玩系列:用20元实现快乐保存器
android·人工智能·算法
青梅橘子皮8 小时前
C语言---指针的应用以及一些面试题
c语言·开发语言·算法
历程里程碑8 小时前
2. Git版本回退全攻略:轻松掌握代码时光机
大数据·c++·git·elasticsearch·搜索引擎·github·全文检索
极客智造8 小时前
深度解析 C++ 类继承与多态:面向对象编程的核心
c++
_深海凉_9 小时前
LeetCode热题100-有效的括号
linux·算法·leetcode
零号全栈寒江独钓11 小时前
基于c/c++实现linux/windows跨平台获取ntp网络时间戳
linux·c语言·c++·windows
CSCN新手听安11 小时前
【linux】高级IO,以ET模式运行的epoll版本的TCP服务器实现reactor反应堆
linux·运维·服务器·c++·高级io·epoll·reactor反应堆