[HNOI 2014]江南乐
Description
给你指定一个数 \(f\) ,并给你 \(T\) 组游戏,每组有 \(n\) 堆石子, \(A,B\) 两人轮流对石子进行操作,每次你可以选择其中任意一堆数量不小于 \(f\) 的石子,平均分为 \(m\) 份(即保证最大的一堆和最小的一堆中石子数量之差不超过 \(1\) )。不能操作者负。
问先手是否有必胜策略。
\(T<100,N<100,F<100000,每堆石子数量<100000\)
Solution
首先对于组合游戏,该游戏的 \(sg\) 函数是各个组分 \(sg\) 函数的 \(nim\) 和。
其次 \(sg(x)=mex\{sg(y)|y是x的后继状态\}\) 。由这两个性质我们可以来求初始状态为 \(n\) 态还是 \(p\) 态。
设法来求 \(sg(x)\) 。
我们可以枚举分的堆数 \(i\) 。
为了使数量尽量平均,我们应该使分出来每堆的石子数量尽可能等于 \(\lfloor\frac{x}{i}\rfloor\) ,如果每一堆分到\(\lfloor\frac{x}{i}\rfloor\) 个石子,那么最后会多出 \(x\mod i\) 个石子。
考虑把这些多出来的石子分别放在分出来的石子堆中,那么有 \(x\mod i\) 堆会分到新的石子。
经过简单的计算,我们可以发现最后有 \(x\mod i\) 堆分到了 \(\lfloor\frac{x}{i}\rfloor+1\) 个石子,有 $ i-(x\mod i)$ 堆分到了 \(\lfloor\frac{x}{i}\rfloor\) 。
由数论分块的思想,对于相同的块内,后继状态 \(y\) 最多只有两种,由于相同的数异或可以抵消,我们可以通过判断 \(x\mod i\) 和 \(i-(x\mod i)\) 的奇偶性来缩小运算规模。
Code
//It is made by Awson on 2018.3.7
#include <bits/stdc++.h>
using namespace std;
const int N = 100000;
int sg[N+5], mex[N+5], t, F, n, x;
int f(int x) {
if (sg[x] != -1) return sg[x];
if (x < F) return sg[x] = 0;
sg[x] = 0;
for (int i = 2; i <= x; i = x/(x/i)+1) {
int tmp = 0;
if ((i-x%i)&1) tmp ^= f(x/i); if ((x%i)&1) tmp ^= f(x/i+1);
mex[tmp] = x;
if (i < x && (x/i == x/(i+1))) {
++i, tmp = 0;
if ((i-x%i)&1) tmp ^= f(x/i); if ((x%i)&1) tmp ^= f(x/i+1);
mex[tmp] = x;
}
}
while (mex[sg[x]] == x) ++sg[x];
return sg[x];
}
void work() {
memset(sg, -1, sizeof(sg));
scanf("%d%d", &t, &F); --t;
while (t--) {
scanf("%d", &n); int ans = 0; while (n--) scanf("%d", &x), ans ^= f(x); printf("%d ", (ans != 0));
}
scanf("%d", &n); int ans = 0; while (n--) scanf("%d", &x), ans ^= f(x); printf("%d\n", (ans != 0));
}
int main() {
work(); return 0;
}
[HNOI 2014]江南乐的更多相关文章
- BZOJ-3576 江南乐 博弈+优化
fye测试原题,高一全跪,高二学长除了CA爷似乎都A辣(逃) 3576: [Hnoi2014]江南乐 Time Limit: 30 Sec Memory Limit: 512 MB Submit: 1 ...
- bzoj 3576[Hnoi2014]江南乐 sg函数+分块预处理
3576: [Hnoi2014]江南乐 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 1929 Solved: 686[Submit][Status ...
- 【BZOJ3576】江南乐(博弈论)
[BZOJ3576]江南乐(博弈论) 题面 BZOJ 洛谷 题解 无论一堆石头怎么拆分,都并不能改变它是一个\(Multi-SG\)的事实. 既然每一组的\(F\)都是固定的,那么我们预处理所有的可能 ...
- 洛谷 P3235 [HNOI2014]江南乐 解题报告
P3235 [HNOI2014]江南乐 Description 两人进行 T 轮游戏,给定参数 F ,每轮给出 N 堆石子,先手和后手轮流选择石子数大于等于 F 的一堆,将其分成任意(大于1)堆,使得 ...
- HNOI 2014
D1T1:画框 frame 题意:给你两个n阶正整数方阵,请你求最大的\( \sum_{i = 1}^{n} A_{i, p_i}\times \sum_{i = 1}^{n} B_{i, p_i} ...
- 【LOJ】#2210. 「HNOI2014」江南乐
LOJ#2210. 「HNOI2014」江南乐 感觉是要推sg函数 发现\(\lfloor \frac{N}{i}\rfloor\)只有\(O(\sqrt{N})\)种取值 考虑把这些取值都拿出来,能 ...
- HNOI 2014 米特运输(图论)
HNOI 2014 米特运输 题目大意 给一棵树,每个点有自己的权值,要求更改一些点的权值,使得整棵树满足两个条件: 同一个父亲的所有子节点权值相同 父节点的取值为所有子节点的和 答案输出最少要更改的 ...
- 「HNOI 2014」 江南乐
\(Description\) \(n\)堆石子,每堆石子有\(s_i\)个,两个人轮流操作,每次可以将一对不少于\(F\)的石子尽量平均分成\(m\)堆,\(m\)每次自选,不能操作者输.共有\(T ...
- 图论(KM算法,脑洞题):HNOI 2014 画框(frame)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABPoAAANFCAIAAABtIwXVAAAgAElEQVR4nOydeVxTV/r/n9ertaJEC4
随机推荐
- Python web服务器
Python 配置wsgi接口# 引入Python wsgi包 from wsgiref.simple_server import make_server # 撰写服务器端程序代码 def Appli ...
- 搭建vue项目环境
前言 在开发本项目之前,我对vue,react,angular等框架了解,仅限于知道它们是什么框架,他们的核心是什么,但是并没有实际使用过(angular 1.0版本用过,因为太难用,所以对这类框架都 ...
- day-2 如何搭建一个github代码库
最近在听尤瓦尔·赫拉利代写的两本书<人类简史>和<未来简史>两本书评,一部描述人类从哪里来,一部描述人类将往哪里去,书中阐述以前我们经历的饥饿.疾病和战争已经渐渐逝去,未来我们 ...
- JS 上传图片时实现预览
网页中一张图片可以这样显示: <img src="http://www.letuknowit.com/images/wg.png"/>也可以这样显示:<img s ...
- JAVA 中的 反射
CLASS类 1) 在面向对象的世界里,万事万物皆对象. 在java中有两样东西不是面向对象 1.普通的数据类型(java中有封装类来弥补它) 2. java中静态的东西 2) 类是对象吗? 类是对象 ...
- Mego开发文档 - 保存关系数据
保存关系数据 由于没有对象的更改跟踪,因此关系的操作需要开发者明确指定,在成功执行后Mego会影响到相应的关系属性中. 添加关系 在以下示例中如果成功执行则source的Customer属性会变为ta ...
- tensorflow安装篇
安装虚拟机redhat7u4-64 镜像文件在http://www.linuxfly.org/post/659 更换yum 参考https://blog.csdn.net/xiaoyiaoyou/ar ...
- MQTT和paho(二)socket
参考链接:http://blog.csdn.net/yangzl2008/article/details/8861069
- redis入门(15)redis的数据备份和恢复
redis入门(15)redis的数据备份和恢复
- SpringCloud的服务注册中心(一)
一.概念和定义 1.服务治理:服务注册与服务发现 服务注册中心,提供服务治理功能,用来实现各个微服务实例的自动注册与发现. 服务注册与发现对于微服务系统来说非常重要.有了服务发现与注册,维护人员就不需 ...