hdoj 1404 Digital Deletions(博弈论)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1404
一看就是博弈论的题目,但并没有什么思路,看了题解,才明白
就是求六位数的SG函数,暴力一遍,打表就OK。
具体的操作是先找P态,即最终无法移动的状态,可知无数可取是P态,0是N态,1是P态,然后从1开始进行暴力,
所有可以到!sg[i]的点标记为N态,暴力过程为标记一步可以到sg[i]的数,包括两类:
一类是仅某一位数字不同,提取方法比较巧妙:
; --i){
int m = x;
;
; j < i; ++j)
;
)) / base;
; ++j){
m += base;
sg[m] = ;//越界了
}
}
另一类是在sg[i]不足6位时在后面填一个0,其后填其他数:
){
int m = x;
;
;i++){
m *= ;
; j < base; ++j)
sg[m+j] = ;
;
}
}
总的代码如下:
#include<stdio.h>
#include<cstring>
using namespace std;
;
int sg[MAXN];
int get_lgt(int x){
) ;
) ;
) ;
) ;
) ;
;
}
void extend(int x){
int lgt = get_lgt(x);
; --i){
int m = x;
;
; j < i; ++j)
;
)) / base;
; ++j){
m += base;
sg[m] = ;//越界了
}
}
//提取每一位的数字,遍历到9
){
int m = x;
;
;i++){
m *= ;
; j < base; ++j)
sg[m+j] = ;
;
}
}
}
// sg[0] = 1;N态 sg[1] = 0;P态
// 终态是P态,可以移动到P态的是N态,所有移动都会导致N态的是P态
void init(){
memset(sg,,sizeof(sg));
sg[] = ;
; i < MAXN; ++i)
if(!sg[i])//N态
extend(i);
}
int main(){
freopen("test.out","r",stdin);
freopen("mtest.out","w",stdout);
init();
];
int lgt;
int n;
while(~scanf("%s",&str)){
n = ;
]==' )
printf("Yes\n");
else{
lgt = strlen(str);
; i < lgt; ++i){
n *= ;
n += str[i]-';
}//字符串转化为整数
if(sg[n])
printf("Yes\n");
else
printf("No\n");
}
}
}
hdoj 1404 Digital Deletions(博弈论)的更多相关文章
- hdu 1404/zoj 2725 Digital Deletions 博弈论
暴力打表!! 代码如下: #include<iostream> #include<algorithm> #include<cstdio> #include<c ...
- Hdu 1404 Digital Deletions
Problem地址:http://acm.hdu.edu.cn/showproblem.php?pid=1404 刚开始想采取找规律的方法解题,可以没有发现规律.无奈,只好采用求PN点的方法. 我们假 ...
- HDU 1404 Digital Deletions (暴力博弈)
题意:给定一个数字串,最长是6,然后有两种操作. 第一种是,把该串中的一个数字换成一个比该数字小的数,比如 5 可以换成 0,1,2,3,4. e.g. 12345 --> 12341 第二 ...
- Digital Deletions HDU - 1404
Digital deletions is a two-player game. The rule of the game is as following. Begin by writing down ...
- HDU 1404 (博弈) Digital Deletions
首先如果第一个数字是0的话,那么先手必胜. 对于一个已知的先手必败状态,凡是能转移到先手必败的状态一定是必胜状态. 比如1是必败状态,那么2~9可以转移到1,所以是必胜状态. 10,10*,10**, ...
- hdu 1404 找sg ***
HDU 1404 Digital Deletions 一串由0~9组成的数字,可以进行两个操作:1.把其中一个数变为比它小的数:2.把其中一个数字0及其右边的所以数字删除. 两人轮流进行操作,最后把 ...
- 博弈论BOSS
基础博弈的小结:http://blog.csdn.net/acm_cxlove/article/details/7854530 经典翻硬币游戏小结:http://blog.csdn.net/acm_c ...
- 【转】ACM博弈知识汇总
博弈知识汇总 转自:http://www.cnblogs.com/kuangbin/archive/2011/08/28/2156426.html 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍 ...
- ACM博弈知识汇总(转)
博弈知识汇总 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍或是围棋子等等均可.两个人轮流从堆中取物体若干,规定最后取光物体者取胜.这是我国民间很古老的一个游戏,别看这游戏极其简单,却蕴含着深刻 ...
随机推荐
- BZOJ 1103 大都市
dfs序+BIT. #include<iostream> #include<cstdio> #include<cstring> #include<algori ...
- KM算法(二分图的最佳完美匹配)
KM算法大概过程: (1)初始化Lx数组为该boy的一条权值最大的出边.初始化Ly数组为 0. (2)对于每个boy,用DFS为其找到一个girl对象,顺路记录下S和T集,并更新每个girl的slac ...
- Service完全解析(转)
今天我们来讲一下Android中Service的相关内容. Service在Android中和Activity是属于同一级别上的组件,我们可以将他们认为是两个好哥们,Activity仪表不凡,迷倒万千 ...
- 13行代碼開發出来的PHP框架[转]
<?PHP /** PHP極簡框架 交流: QQ群: 223494678 http://7di.net 用法 http://URL http://URL/hello http://URL/sev ...
- 【C#学习笔记】文本复制到粘贴板
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- 在Linux上安装多Jboss个需要修改的端口
如果在一台机器上部署了多个jboss server,需要修改相关端口以避免端口冲突.目前确认需要修改的配置如下一.vi $JBOSS_HOME/server/default/conf/jboss-se ...
- PHP中设置、使用、删除Cookie方法
1.设置Cookie PHP用SetCookie函数来设置Cookie.必须注意的一点是:Cookie是HTTP协议头的一部分,用于浏览器和服务器之间传递信息,所以必须在任何属于HTML文件本身的内容 ...
- 10、NFC技术:读写NFC标签中的文本数据
代码实现过程如下: 读写NFC标签的纯文本数据.java import java.nio.charset.Charset; import java.util.Locale; import androi ...
- c++中实现委托
成员函数指针与高性能的C++委托(上篇) 撰文:Don Clugston 引子 标准C++中没有真正的面向对象的函数指针.这一点对C++来说是不幸的,因为面向对象的指针(也叫做"闭包(clo ...
- 浅谈“be practical and realistic”
一 “实事求是”这个词,一般认为是古人的一种治学观念,后来经咏芝的发明.阐释.以及“应用”,成为“基本思想路线”(具体可参看大学思想政治教科书),被称为“活的灵魂”.这里不想过多地牵扯政治话题,仅就我 ...