acm--博弈入门2(P/N分析)--(HDU 1847 HDU 2188 HDU 3863)
P/N理论
分析博弈时可以用P/N分析法
具体如下:
P点:即必败点,某玩家位于此点,只要对方无失误,则必败;
N点:即必胜点,某玩家位于此点,只要自己无失误,则必胜。
必败态:一定输
必胜态:一定赢
奇异局势:必败态局势
非奇异局势:必胜态局势
P/N点满足三个定理:
- 所有终结点都是必败点P(游戏中,轮到谁拿牌,还剩0张牌的时候,此人就输了,因为无牌可取)(游戏规则特殊的不考虑);
- 所有一步能走到必败点P的就是N点;
- 通过一步操作只能到N点的就是P点;
如最简单的巴什博弈中的取石子问题,假设每个人最多取3个,共9个:
0为必败点P,1,2,3可以通过取1,2,3个得到0这个必败点,于是1,2,3是N必胜点,而4不可以通过取1,2,3得到必败点,所以4是新的必败点。
以此类推,可以列一张0到8的表(这可以帮我们理解)
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
|---|---|---|---|---|---|---|---|---|---|
| P | N | N | N | P | N | N | N | P | N |
我们一开始拿1个,让对手进入必败态(奇异局势),就可以赢。
但具体题目中,我们用8 % (3 + 1) != 0
理论补充:对于奇异局势你一定能把它变成非奇异局势,一定不能把它变成奇异局势(不然你就一直赢了);
对于非奇异局势,你可以通过才智把它变成奇异局势,也能变成非奇异局势
看题目吧,少年!
基础博弈变形
假设有13个石子,双方可以取1,3,4个,你先取,问怎样才能稳赢?
我们可以先列一张表
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| P | N | P | N | N | N | N | P | N | P | N | N | N | N |
从表中可以看出,你要先取4个,让对手达到必败态 。
要判断是否是奇异局势也很简单:13%(2+(4+1))!=0或13%(2+(4+1))!=2即可
水几题吧!!!
先自己做做吧。(我就不做超链接了)
hdu1847
hdu2188
hdu3863
hdu1847
哈哈,分析后,3的倍数为必败-。-
#include<stdio.h>
int main()
{
int n;
while(scanf("%d", &n)==1)
{
if (n % 3 == 0)
printf("Cici\n");
else
printf("Kiki\n");
}
return 0;
}
hdu2188
水水水。。。
#include<stdio.h>
int main()
{
int n,a,b;
while (scanf("%d", &n) ==1)
{
while (n--)
{
scanf("%d%d", &a, &b);
if (a > b&&a%(b+1)==0)
printf("Rabbit\n");
else
printf("Grass\n");
}
}
return 0;
}
hdu3863
先手必胜
#include<stdio.h>
int main()
{
long int n;
while (scanf("%ld", &n) ==1&&n!=-1)
{
printf("I bet on Oregon Maple~\n");
}
return 0;
}
acm--博弈入门2(P/N分析)--(HDU 1847 HDU 2188 HDU 3863)的更多相关文章
- 【转】ACM博弈知识汇总
博弈知识汇总 转自:http://www.cnblogs.com/kuangbin/archive/2011/08/28/2156426.html 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍 ...
- ACM博弈知识汇总(转)
博弈知识汇总 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍或是围棋子等等均可.两个人轮流从堆中取物体若干,规定最后取光物体者取胜.这是我国民间很古老的一个游戏,别看这游戏极其简单,却蕴含着深刻 ...
- HDU.1847 Good Luck in CET-4 Everybody! ( 博弈论 SG分析)
HDU.1847 Good Luck in CET-4 Everybody! ( 博弈论 SG分析) 题意分析 简单的SG分析 题意分析 简单的nim 博弈 博弈论快速入门 代码总览 //#inclu ...
- hdu 1847 Good Luck in CET-4 Everybody!(巴什博弈)
Good Luck in CET-4 Everybody! HDU - 1847 大学英语四级考试就要来临了,你是不是在紧张的复习?也许紧张得连短学期的ACM都没工夫练习了,反正我知道的Kiki和Ci ...
- HDU 1847 Good Luck in CET-4 Everybody! (巴什博弈)
题目链接:HDU 1847 Problem Description 大学英语四级考试就要来临了,你是不是在紧张的复习?也许紧张得连短学期的ACM都没工夫练习了,反正我知道的Kiki和Cici都是如此. ...
- HDU 1847 Good Luck in CET-4 Everybody!(规律,博弈)
Good Luck in CET-4 Everybody! Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K ...
- HDU 1847 Good Luck in CET-4 Everybody! (博弈)
题意:不用说了吧,都是中文的. 析:虽说这是一个博弈的题,但是也很简单的,在说这个题目前我们先说一下巴什博弈定理. 巴什博弈定理:一堆物品有n个,有两个人(两个人足够聪明)轮流取,规定每次至少取一个, ...
- HDOJ 1846 Brave Game - 博弈入门
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1846 经典基础博弈,首先面对(m+1)的人一定会输,依次往后推即可: #include<iost ...
- ACM 博弈(难)题练习 (第一弹)
第二弹: 套路&&经验总结: 1. N堆***的游戏,一般可以打表找SG函数的规律.比如CodeForces 603C 2.看起来是单轮的游戏,实际上可能拆分成一些独立的子游戏.比如C ...
随机推荐
- C#异常断电后重新启动项目出现配置未初始化错误
转到如截图中所示路径,将其下的数据删掉,就可以启动了.
- [转] babel的使用
一.配置文件.babelrc .babelrc 文件存放在项目的根目录下. { "presets": [], "plugins": [] } presets 字 ...
- JSP中out.print()、out.println()以及out.write()的区别
out是JSP九大内置对象之一,是JspWriter的一个对象,JspWriter继承了java.io.Writer类. out.print()和out.write() print()和println ...
- bzoj3992
题解: 求模素数 p 原根的方法:对 p-1 进行素因子分解,记pi为p-1的第i个因子,若恒有a^((p-1)/pi) mod p ≠ 1 成立,则 a 就是 p 的原根.(对于合数求原根,只需把 ...
- Python学习(二十三)—— 前端基础之jQuery
转载自http://www.cnblogs.com/liwenzhou/p/8178806.html 一.jQuery入门 jQuery是一个轻量级的.兼容多浏览器的JavaScript库. jQue ...
- 元素滚动到底部或顶部时阻止body滚动
移动端的弹窗内容有滚动条,滚动到底部或顶部时或影响弹窗下的body滚动,某些浏览器滚动到顶部时不松手就触发了刷新页面的情况,如果不需要这样的默认体验,就需要加一下判断了. var startX,sta ...
- Codeforces 1016G Appropriate Team 数论 FWT
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1016G.html 题目传送门 - CF1016G 题意 给定 $n,x,y$ ,以及一个含有 $n$ 个元 ...
- Codeforces 986C AND Graph dfs
原文链接https://www.cnblogs.com/zhouzhendong/p/9161514.html 题目传送门 - Codeforces 986C 题意 给定 $n,m (0\leq n\ ...
- Collection接口的常用方法
[添加功能] boolean add(Object obj); //添加一个元素. boolean addAll(Collection c); //添加一个集合的元素(在后面追加). [删除功能] v ...
- EditPlus文本库编辑说明
EditPlus3 “编辑”命令(素材文本组合框弹出菜单)使用此命令载入当前的素材文本库文件(扩展名为“.CTL”)到编辑器中并直接编辑它.素材文本库文件必须按预定义语法编写.该语法非常简单.最快的方 ...