注册 登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

Yavin(某沙茶的代码库)

Star Wars fan and OIer

 
 
 

日志

 
 

SGU153  

2012-02-28 13:13:46|  分类: SGU100系列 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
取石子游戏
打个表
发现SG函数周期性分布
恶搞开始

#include<cstdio>
#include<cstdlib>
#include<cstring>

const int MAX=10000;
const int N=10;
int test,n,m;
int p[N];
int f[MAX+10],time;

int main()
{
scanf("%d",&test);
while(test--)
{
int i,j;
scanf("%d %d",&n,&m);
++m;
p[1]=1;
for(i=2;i<=m;++i)
scanf("%d",&p[i]);
memset(f,0,sizeof(f));
for(i=2;i<=MAX;++i)
for(j=1;j<=m;++j)
if(i>p[j]&&!f[i-p[j]])
{
f[i]=1;
continue;
}
int flag=1;
for(time=1;time<100;++time)
{
flag=1;
for(i=1;i<=time;++i)
{
for(j=0;i+(j+1)*time<=MAX;++j)
if(f[i+j*time]!=f[i+(j+1)*time])
flag=0;
if(!flag)break;
}
if(flag)break;
}
int now=n%time==0?time:n%time;
if(f[now])
printf("FIRST PLAYER MUST WIN\n");
else printf("SECOND PLAYER MUST WIN\n");
}
}



  评论这张
 
阅读(124)| 评论(1)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018