51nod_1661: 黑板上的游戏(sg函数 找规律)
先打一个sg函数的表,找找规律,发现sg函数可以递归求解
打表代码如下
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
;
bool vis[N];
int sg[N];
int k;
void init()
{
memset(sg,,sizeof(sg));
memset(vis,false,sizeof(vis));
sg[]=,sg[]=;
;i<=;i++)
{
memset(vis,,sizeof(vis));
)/k;j<i;j++)
vis[sg[j]]=true;
;j<=;j++)
if(vis[j]==false)
{
sg[i]=j;
break;
}
}
}
int main()
{
ios::sync_with_stdio(false);
while(cin>>k)
{
init();
;i<=;i++)
{
printf(? '\n':' ');
}
puts("");
puts("");
}
}
得到的一个结果
k= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]= sg[ ]=
当然k可以改来改去地试
再之后,如果异或和不为0,要特殊处理下,也是根据打表的规律,具体方法见代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
;
LL k;
int n;
LL a[N];
LL sg(LL x)
{
||x==) ;
)
)/k;
return sg(x/k);
}
int main()
{
while(~scanf("%d%lld",&n,&k))
{
LL ans=;
;i<=n;i++)
{
scanf("%lld",&a[i]);
ans^=sg(a[i]);
}
// cout<<ans<<endl;
if(ans)
{
int pos;
LL y;
;i<=n;i++)
{
LL sgx=sg(a[i]),t=sgx^ans;
pos=i;
y=t+(t+k-)/(k-);
// cout<<y<<' '<<(a[i]+k-1)/k<<endl;
)
{
if(y>=a[i]) break;
)/k)
{
printf("Alice %d %lld\n",pos,y);
;
}
y=y*k+;
}
}
printf("Alice %d %lld\n",pos,y);
}
else
puts("Bob");
}
}
51nod_1661: 黑板上的游戏(sg函数 找规律)的更多相关文章
- BZOJ 1228 E&G(sg函数+找规律)
把一对石子堆看出一个子游戏.打出子游戏的sg表找规律.. 这个规律我是一定找不出来的... 对于i,j,如果 (i-1)%pow(2,k+1) < pow(2,k) (j-1)%pow(2,k+ ...
- 51nod 1661: 黑板上的游戏(sg函数 找规律)
题目链接 先打一个sg函数的表,找找规律,发现sg函数可以递归求解 打表代码如下 #include<bits/stdc++.h> using namespace std; typedef ...
- HDU-4664 Triangulation 博弈,SG函数找规律
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4664 题意:一个平面上有n个点(一个凸多边形的顶点),每次可以连接一个平面上的两个点(不能和已经连接的 ...
- HDU 1517 A Multiplication Game (SG函数找规律)
题意:两个玩家玩一个游戏,从 p = 1,开始,然后依次轮流选择一个2 - 9的数乘以 p,问你谁先凑够 p >= n. 析:找规律,我先打了一下SG函数的表,然后就找到规律了 我找到的是: 1 ...
- 51nod-1661 1661 黑板上的游戏(组合游戏)
题目链接: 1661 黑板上的游戏 Alice和Bob在黑板上玩一个游戏,黑板上写了n个正整数a1, a2, ..., an,游戏的规则是这样的:1. Alice占有先手主动权.2. 每个人可以选取一 ...
- 组合游戏 - SG函数和SG定理
在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念: P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败. N点:必胜点 ...
- 【poj 3090】Visible Lattice Points(数论--欧拉函数 找规律求前缀和)
题意:问从(0,0)到(x,y)(0≤x, y≤N)的线段没有与其他整数点相交的点数. 解法:只有 gcd(x,y)=1 时才满足条件,问 N 以前所有的合法点的和,就发现和上一题-- [poj 24 ...
- HDU 1536 S-Nim (组合游戏+SG函数)
题意:针对Nim博弈,给定上一个集合,然后下面有 m 个询问,每个询问有 x 堆石子 ,问你每次只能从某一个堆中取出 y 个石子,并且这个 y 必须属于给定的集合,问你先手胜还是负. 析:一个很简单的 ...
- BZOJ1188 [HNOI2007]分裂游戏(SG函数)
传送门 拿到这道题就知道是典型的博弈论,但是却不知道怎么设计它的SG函数.看了解析一类组合游戏这篇论文之后才知道这道题应该怎么做. 这道题需要奇特的模型转换.即把每一个石子当做一堆石子,且原来在第i堆 ...
随机推荐
- Hadoop SSH+IP、SSH+别名 免密登录配置
1.为什么要进行 SSH 无密码验证配置? Hadoop运行过程中需要管理远端Hadoop守护进程,在Hadoop启动以后,NameNode是通过SSH(Secure Shell)来启动和停止各个Da ...
- cpp(第十三章)
1.动态(晚期)联编需要显示定义复制构造函数,赋值运算符,虚构函数. 2.纯虚类不能声明对象. 3.赋值运算符的特征标随类而异. 4.返回类型协变,重新定义继承的方法,应确保与原来的原型完全相同,但如 ...
- 禅道---Bug管理模块
禅道官网:http://www.cnezsoft.com/ 简介: 开源免费的项目管理软件.集产品管理.项目管理.测试管理一体以及事物管理组织管理的功能 使用原因: 开源 方便跟踪管理Bug 使用简单 ...
- Bash扩展顺序
当进行变量替换.命令替换.数学扩展以及路径扩展时,Bash Shell遵循如下顺序: 1.大括号扩展 $ls f{oo,aa,unble} 2.~扩展 ~cb, ~/doc/working 3.命令参 ...
- Java IO学习笔记五
管道流 管道流的主要作用是可以进行两个线程间的通讯,分为管道输出流(PipedOutputStream).管道输入流(PipedInputStream),如果想要进行管道输出,则必须要把输出流连在输入 ...
- .net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结(一)
我们知道Kafka支持Consumer Group的功能,但是最近在应用Consumer Group时发现了一个Topic 的Partition不能100%覆盖的问题. 程序部署后,发现Kafka在p ...
- 10亿美元融资腾讯跟头,Grail要用基因测序做癌症早期筛查
癌症超早期筛查:"在干草堆中寻找缝衣针"癌症是人类的噩梦,尤其是中晚期癌症,但很多时候,当患者感觉到身体不适而去医院检查时,病情都已经到了中晚期,很难治愈.而有研究表明,早期癌症患 ...
- 增强学习 | AlphaGo背后的秘密
"敢于尝试,才有突破" 2017年5月27日,当今世界排名第一的中国棋手柯洁与AlphaGo 2.0的三局对战落败.该事件标志着最新的人工智能技术在围棋竞技领域超越了人类智能,借此 ...
- Redis中的数据对象
redis对象 redis中有五种常用对象 我们所说的对象的类型大多是值的类型,键的类型大多是字符串对象,值得类型大概有以下几种,但是无论哪种都是基于redisObject实现的 redisObjec ...
- 如何编写一个带命令行参数的Python文件
看到别人执行一个带命令行参数的python文件,瞬间觉得高大上起来.牛逼起来,那么如何编写一个带命令行参数的python脚本呢?不用紧张,下面将简单易懂地让你学会如何让自己的python脚本,支持带命 ...