Every-SG游戏
参考自 石家庄二中 贾志豪 IOI2009国家集训队论文 《组合游戏略述—— 浅谈 SG 游戏的若干拓展及变形》
一、定义
游戏规则加上 对于还没有结束的所有单一游戏,游戏者必须对其进行决策
二、结论
对于必胜的单一游戏,游戏者希望玩的越久越好
对于必败的单一游戏,游戏者希望越早结束越好
因为Every-SG 游戏的获胜方取决于坚持到最后的游戏者
所以
对于必胜态,需要知道最慢几步可以结束游戏
对于必败态,需要知道最快几步可以结束游戏
令step表示结束游戏的步数
那么
若状态S是结束状态,那么step(s)=0
若状态S是先手必胜态,那么step(s)=max(step(t))+1,其中满足t是先手必败态
若状态S是先手必败态,那么step(s)=min(step(s))+1
定理:
Every-SG 游戏先手必胜当且仅当单一游戏中最大的step为奇数。
三、证明
要证明结论的正确性,需证明以下三点:
1、若S为先手必胜态,则step(s)=奇数,否则step(s)=偶数
因为Every-SG 游戏的获胜方取决于坚持到最后的游戏者,所以游戏的获胜方取决于最大的step。
2、设最大的step为step_max,那么获胜方要保证游戏 在>=step_max 步结束
3、设最大的step为step_max,那么获胜方要保证所有的必败单一游戏在<=step_max步结束
这两点显然
证明1:数学归纳法,终止状态为先手必败态,step=0=偶数,往前推即可
证明2:
设step最大的单一游戏为A,获胜方为W
W总在A处于先手必胜态时移动A的状态,而它又希望游戏持续时间越长越好,所以只会使A的step减少1
对方总是在A处于先手必败态时移动A的状态,而处于先手必败态时,step是后继状态的step取min+1,所以对方至多使step减少1
这里的减少x指转移到step-x的后继状态
所以 游戏在>=step_max 步内结束
证明3:
设获胜方为W,其某一个必败单一游戏为B
W总是在B处于先手必败态时移动B的状态,所以他希望这个游戏越早结束越好,此时的step是后继状态的step取min+1,所以W一定会使step减少1
对方总是在B处于先手必胜态时移动B的状态,此时step是后继状态的step取max+1,所以对方至少使step减少1
所以游戏B在<=step_max 步结束
四、例题
题意:
N组石子,每组有两堆,每次可以从一堆中取走另一堆的倍数个石子,N组石子同时操作
#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std; #define N 1001 int sg[N][N];
int step[N][N]; int find(int a,int b)
{
if(a>b) swap(a,b);
if(sg[a][b]!=-) return sg[a][b];
int mi=1e9,mx=-;
for(int i=a;i<=b;i+=a)
if(!find(a,b-i))
{
sg[a][b]=sg[b][a]=;
mx=max(mx,step[a][b-i]);
}
else mi=min(mi,step[a][b-i]);
if(sg[a][b]==)
{
step[a][b]=step[b][a]=mx+;
return true;
}
step[a][b]=step[b][a]=mi+;
return sg[a][b]=sg[b][a]=;
} int main()
{
int n,a,b;
int ans;
memset(sg,-,sizeof(sg));
for(int i=;i<N;++i) sg[][i]=sg[i][]=;
while(scanf("%d",&n)!=EOF)
{
ans=;
for(int i=;i<=n;++i)
{
scanf("%d%d",&a,&b);
find(a,b);
ans=max(ans,step[a][b]);
}
puts(ans& ? "MM" : "GG");
}
}
Every-SG游戏的更多相关文章
- [BZOJ 1874] [BeiJing2009 WinterCamp] 取石子游戏 【博弈论 | SG函数】
题目链接:BZOJ - 1874 题目分析 这个是一种组合游戏,是许多单个SG游戏的和. 就是指,总的游戏由许多单个SG游戏组合而成,每个SG游戏(也就是每一堆石子)之间互不干扰,每次从所有的单个游戏 ...
- 每一个可以移动的棋子都要移动——Every-SG 游戏
先看一个问题 HDU 3595 GG and MM (Every_SG博弈) 题目有N个游戏同时进行,每个游戏有两堆石子,每次从个数多的堆中取走数量小的数量的整数倍的石子.取最后一次的获胜.并且N个游 ...
- 【BZOJ】【1022】【SHOI2008】小约翰的游戏John
博弈论 一看题,哇这不是Nim游戏么= =直接异或起来……啊咧怎么不对? 这道题是[Anti-Nim],普通的Nim是取走最后一个就赢,这题是取走最后一个输…… 做法参见 2009年贾志豪论文< ...
- BZOJ_1022_[SHOI2008]_小约翰的游戏John_(博弈论_反Nim游戏)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1022 反Nim游戏裸题.详见论文<组合游戏略述——浅谈SG游戏的若干拓展及变形>. ...
- poj 3710 Christmas Game(树上的删边游戏)
Christmas Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1967 Accepted: 613 Des ...
- POJ 3710 Christmas Game#经典图SG博弈
http://poj.org/problem?id=3710 (说实话对于Tarjan算法在搞图论的时候就没搞太懂,以后得找时间深入了解) (以下有关无向图删边游戏的资料来自论文贾志豪<组合游戏 ...
- [BZOJ1022] [SHOI2008] 小约翰的游戏John (SJ定理)
Description 小约翰经常和他的哥哥玩一个非常有趣的游戏:桌子上有n堆石子,小约翰和他的哥哥轮流取石子,每个人取的时候,可以随意选择一堆石子,在这堆石子中取走任意多的石子,但不能一粒石子也不取 ...
- 博弈论进阶之Anti-SG游戏与SJ定理
前言 在上一节中,我们初步了解了一下SG函数与SG定理. 今天我们来分析一下SG游戏的变式--Anti-SG游戏以及它所对应的SG定理 首先从最基本的Anti-Nim游戏开始 Anti-Nim游戏是这 ...
- 简单易懂的博弈论讲解(巴什博弈、尼姆博弈、威佐夫博弈、斐波那契博弈、SG定理)
博弈论入门: 巴什博弈: 两个顶尖聪明的人在玩游戏,有一堆$n$个石子,每次每个人能取$[1,m]$个石子,不能拿的人输,请问先手与后手谁必败? 我们分类讨论一下这个问题: 当$n\le m$时,这时 ...
随机推荐
- MYSQL InnoDB Cluster
https://dev.mysql.com/doc/refman/5.7/en/group-replication.html GroupReplication的原理 https://dev.mysql ...
- Jmeter常见问题及场景应用
Jmeter作为工具来讲,已经是一个相对比较牛掰的工具,除了它能够支持那么多协议以及方法之外,更在与它的前置处理以及后置处理.同步监控的人性化.当然,所有的工具.框架都是作为业务的支撑,如果不能满足我 ...
- [转帖]知乎专栏:正确使用 Docker 搭建 GitLab 只要半分钟
正确使用 Docker 搭建 GitLab 只要半分钟 https://zhuanlan.zhihu.com/p/49499229 很多程序员在内网搭建 gitlab 都搭建的坑坑洼洼,不支持 htt ...
- K3CLOUD安装教程
1.安装SQLSERVER2008 2.安装K3CLOUD安装包,此处各种安装iis,tomcat,ftp等环境,有过it经验的应该都能自己搞定,不详细赘述 3.进入管理中心,进行设置,默认为127. ...
- 用SoapUI 测试Web Service
如何测试写好的Webservice? 方法一:写代码来测试,但还是太麻烦,你得花时间去学习各语言的关于Webservice调用的相关API. 方法二:使用Webservice开发的必备工具- Soap ...
- pgm14
这部分讨论在有数据缺失情况下的 learning 问题,这里仍然假定了图结构是已知的. 首先需要讨论的是为什么会缺失,很多情况下缺失并不是“随机”的:有的缺失是人为的,那么某些情况下缺失的可以直接补上 ...
- BZOJ4832[Lydsy1704月赛]抵制克苏恩——期望DP
题目描述 小Q同学现在沉迷炉石传说不能自拔.他发现一张名为克苏恩的牌很不公平.如果你不玩炉石传说,不必担心,小Q 同学会告诉你所有相关的细节.炉石传说是这样的一个游戏,每个玩家拥有一个 30 点血量的 ...
- BZOJ1146[CTSC2008]网络管理——出栈入栈序+树状数组套主席树
题目描述 M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个 部门之间协同工作,公司搭建了一个连接整个公司的通信网络.该网络的结构由N个路由器和N-1条 ...
- 【Linux】Centos配置ssh无密码登录
[测试环境] 刚好重新做mgr就搞下吧,主要论文好长~想多做几遍再看~ master1 192.168.13.111 master2 192.168.13.112 master3 192.168. ...
- python 模块 - 序列化 json 和 pickle
1,引入 之前我们学习过用eval内置方法可以将一个字符串转成python对象,不过,eval方法是有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,eval ...