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堆 ...
随机推荐
- Delphi使用Zint生成QR二维条码(zint.dll)
Delphi使用Zint生成QRCODE 本文使用的Zint Barcode Library(zint.dll)版本为2.6.0,和之前使用的2.4.3版本在zint_symbol这个结构体上会有差异 ...
- javaCV开发详解之6:本地音频(话筒设备)和视频(摄像头)抓取、混合并推送(录制)到服务器(本地)
javaCV系列文章: javacv开发详解之1:调用本机摄像头视频 javaCV开发详解之2:推流器实现,推本地摄像头视频到流媒体服务器以及摄像头录制视频功能实现(基于javaCV-FFMPEG.j ...
- 关于URL的理解
引言 URL,是统一资源定位符(Uniform Resource Locator)的缩写,一个URL就是一个特定资源在网络上的地址.理论上讲,一个URL指向一个唯一的资源,这个资源可以使一个HTML页 ...
- 再来写一个随机数解决方案,对Random再来一次封装
本文提供对Random的封装,简化并扩展了其功能 获取随机数,确保同时调用不会重复 //new Random().Next(5); RandomTask.Next(); 从一个列表中,随机获取其中某个 ...
- 利用angular控制元素的显示和隐藏
<!DOCTYPE html> <html lang="en" ng-app="myapp"> <head> <met ...
- Linux下串口通信工具minicom的用法
一.查看串口设备 例如,将USB转串口线插入交换机Console口后,执行命令:$ll /dev/ttyUSB* 二.连接串口设备 $sudo minicom -D /dev/ttyUSB0 三.设置 ...
- 制作Ubuntu Kylin局域网源
国人参与开发的开源操作系统UbuntuKylin(http://www.ubuntukylin.com/)已经发布有一段时间了,一直想在单位的局域网内部用用,可惜离线安装比较麻烦,于是搜索了些如何制作 ...
- 多重bash登入的history写入问题
问题:如果一个用户同时开好几个 bash 接口, 这时~/.bash_history中会写入哪个bash的历史命令记录? 答:所有的bash 都有自己的 HISTSIZE 笔记录在内存中,因为等到注销 ...
- Scrapy爬虫大战京东商城
Scrapy爬虫大战京东商城 引言 上一篇已经讲过怎样获取链接,怎样获得参数了,详情请看python爬取京东商城普通篇 代码详解 首先应该构造请求,这里使用scrapy.Request,这个方法默认调 ...
- Python 任务队列 Celery
一. celery 简介 Celery 是一个专注于实时处理和任务调度的分布式任务队列, 同时提供操作和维护分布式系统所需的工具.. 所谓任务就是消息, 消息中的有效载荷中包含要执行任务需要的全部数据 ...