POJ 2311 Cutting Game (SG函数)

来源:互联网 发布:网络没问题lol延迟高 编辑:程序博客网 时间:2024/05/29 15:11

转载请注明出处,谢谢 http://blog.csdn.net/ACM_cxlove?viewmode=contents           by---cxlove

题目:给出一个N*M的纸片,每一次可以把一部分剪成两部分,谁剪出1*1的就赢了。

http://poj.org/problem?id=2311

对于任何一个人,都不会先剪出1*n或者n*1,应该这样就必败了。

那我们考虑一个状态的后继中,最小的边也是2,这样就可以避免之前的问题,也不需要考虑类似ANTI-SG。

一旦出现2*2,2*3,3*2,这些都成了终止状态,不论怎么剪都会出现1*n,或者n*1

还是考察SG函数


#include<iostream>#include<cstdio>#include<ctime>#include<cstring>#include<cstdlib>#include<vector>#define C    240#define TIME 10#define LL long longusing namespace std;int sg[205][205];int get_sg(int n,int m){    if(sg[n][m]!=-1)        return sg[n][m];    int vis[1005];    memset(vis,0,sizeof(vis));    for(int i=2;i<=n-i;i++)        vis[get_sg(i,m)^get_sg(n-i,m)]=1;    for(int i=2;i<=m-i;i++)        vis[get_sg(n,i)^get_sg(n,m-i)]=1;    for(int i=0;;i++)        if(vis[i]==0)            return sg[n][m]=i;}int main(){    int n,m;    memset(sg,-1,sizeof(sg));    while(scanf("%d%d",&n,&m)!=EOF)        if(get_sg(n,m))            printf("WIN\n");        else            printf("LOSE\n");    return 0;}


原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 打过流脑后发烧怎么办 甲醛公司除完后怎么办 发票系统导出的xml 怎么办 新买的书包味道太大怎么办 alt+a截图热键冲突怎么办 白背心领发黄了怎么办 房屋装修后出现质量问题怎么办 华为p9手机音量小怎么办 华为畅享8玩游戏卡怎么办 华为畅享7玩游戏卡怎么办 华为p9升级以后屏幕失灵怎么办 荣耀9青春版玩游戏卡怎么办 华为p9屏幕不亮了怎么办 华为p9入水黑屏怎么办 农信密码忘记了怎么办 小米4g信号差怎么办 手机的调频调制器坏了怎么办 调制解调器的灯一直闪怎么办 691宽带用户名和密码无效怎么办 房间里有狐臭味怎么办 吃冰冻水果胃特别痛怎么办 小米5s屏幕闪烁怎么办 系统重装重启了怎么办 华为p10开不了机怎么办 眼镜腿夹的头疼怎么办 摩托车车头锁坏了怎么办 夏天骑摩托车戴头盔热怎么办 头盔玻璃罩边固定老是掉怎么办 电动车不戴头盔被扣车怎么办 郴州骑电动车没戴头盔怎么办 配置数据源时发现两个版本怎么办 微信占用内存3g怎么办 打印机显示内存已满怎么办 网页显示代理服务器连接失败怎么办 墙内线路断了怎么办 墙里的电线坏了怎么办 鱼竿最前端断了怎么办 下雨天墙壁与管道间漏水怎么办 电饭锅的电线被雨淋了怎么办 钢琴跨八度手短怎么办 弹钢琴手指不灵活怎么办呢?