题目描述

两人进行 $T$ 轮游戏,给定参数 $F$ ,每轮给出 $N$ 堆石子,先手和后手轮流选择石子数大于等于 $F$ 的一堆,将其分成任意(大于1)堆,使得这些堆中石子数最多的和最少的相差不超过1(即尽量均分)。求先手和后手谁必胜。

输入

输入第一行包含两个正整数T和F,分别表示游戏组数与给定的数。
接下来T行,每行第一个数N表示该组游戏初始状态下有多少堆石子。之后N个正整数,表示这N堆石子分别有多少个。

输出

输出一行,包含T个用空格隔开的0或1的数,其中0代表此时小A(后手)会胜利,而1代表小A的对手(先手)会胜利。

样例输入

4 3 
1 1 
1 2 
1 3 
1 5

样例输出

0 0 1 1


题解

博弈论+SG定理+数学

显然游戏为多状态组合游戏,考虑使用SG定理求解。

SG定理:定义每种局面的SG函数值为该局面所有子局面SG函数值的mex,多状态组合游戏的SG值为每个状态SG值的异或。SG值为0时先手必败,否则先手必胜。

设 $f[i]$ 表示一堆 $i$ 个石子的SG函数值,当 $i<f$ 时 $f[i]=0$ 。枚举分成的堆数 $j$ ,根据定义有 $f[i]=\text{mex}_{j=2}^{i}f[\frac ij]\text{^}f[\frac ij]\text{^}...\text{^}f[\frac ij]\text{^}f[\frac ij+1]\text{^}f[\frac ij+1]\text{^}...\text{^}f[\frac ij+1]$ 。
其中 $\text{^}$ 表示异或,$f[\frac ij]$ 有 $j-i\%j$ 个,$f[\frac ij+1]$ 有 $i\%j$ 个,$\%$ 表示模。

这里出现了 $\frac ij$ ,可以使用数学下底分块的方法枚举商,求出 $\frac ij$ 相等的一段区间。

由于 $x\text{^}x=0$ ,因此只需要考虑 $j-i\%j$ 和 $i\%j$ 的奇偶性即可。

又因为 $i\%j=i-j·\frac ij$ ,因此当 $\frac ij$ 为定值时,相同奇偶性的 $j$ 对应的答案相同。

具体来讲 ,$\text{mex}$ 后面的部分当 $j$ 为偶数时:$i$ 为奇数时为 $f[\frac ij]\text{^}f[\frac ij+1]$ ,否则为 $0$ ;当 $j$ 为奇数时:$i-j$ 为奇数为 $f[\frac ij+1]$ ,否则为 $f[\frac ij]$ 。

之后暴力求 $\text{mex}$ 即可(复杂度是对的)。

最后对于询问,将每堆的SG值异或即可得到最终的SG值。

时间复杂度 $O(n\sqrt n)$ 。

bzoj上比较卡常,需要使用时间戳优化来记录每个SG是否作为子状态出现。

#include <cstdio>
#include <algorithm>
using namespace std;
int f[100010] , v[100010];
inline void calc(int n , int c)
{
int i , t , last;
for(i = 2 ; i <= n ; i = last + 1)
{
t = n / i , last = n / t;
if(last / 2 > (i - 1) / 2)
{
if(n & 1) v[f[t] ^ f[t + 1]] = c;
else v[0] = c;
}
if((last + 1) / 2 > i / 2)
{
if((n - t) & 1) v[f[t + 1]] = c;
else v[f[t]] = c;
}
}
}
int main()
{
int T , c , i , n , x , val;
scanf("%d%d" , &T , &c);
for(i = c ; i < 100000 ; i ++ )
{
calc(i , i);
while(v[f[i]] == i) f[i] ++ ;
}
while(T -- )
{
scanf("%d" , &n) , val = 0;
for(i = 1 ; i <= n ; i ++ ) scanf("%d" , &x) , val ^= f[x];
printf("%d" , (bool)val);
if(T) printf(" ");
}
return 0;
}

【bzoj3576】[Hnoi2014]江南乐 博弈论+SG定理+数学的更多相关文章

  1. bzoj3576: [Hnoi2014]江南乐

    Description 小A是一个名副其实的狂热的回合制游戏玩家.在获得了许多回合制游戏的世界级奖项之后,小A有一天突然想起了他小时候在江南玩过的一个回合制游戏.    游戏的规则是这样的,首先给定一 ...

  2. [HNOI2014]江南乐 博弈论

    题面 题面 题解 首先我们知道一个关于除法的重要性质:对于一个固定的\(i\),表达式\(\frac{i}{m}\)的取值只有根号个. 因此我们考虑如何优化SG函数的求解. 观察到在取值相同的同一段中 ...

  3. bzoj 3576[Hnoi2014]江南乐 sg函数+分块预处理

    3576: [Hnoi2014]江南乐 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 1929  Solved: 686[Submit][Status ...

  4. 【BZOJ3576】江南乐(博弈论)

    [BZOJ3576]江南乐(博弈论) 题面 BZOJ 洛谷 题解 无论一堆石头怎么拆分,都并不能改变它是一个\(Multi-SG\)的事实. 既然每一组的\(F\)都是固定的,那么我们预处理所有的可能 ...

  5. 洛谷 P3235 [HNOI2014]江南乐 解题报告

    P3235 [HNOI2014]江南乐 Description 两人进行 T 轮游戏,给定参数 F ,每轮给出 N 堆石子,先手和后手轮流选择石子数大于等于 F 的一堆,将其分成任意(大于1)堆,使得 ...

  6. 【bzoj3576】[Hnoi2014]江南乐 数论分块+博弈论

    Description 小A是一个名副其实的狂热的回合制游戏玩家.在获得了许多回合制游戏的世界级奖项之后,小A有一天突然想起了他小时候在江南玩过的一个回合制游戏. 游戏的规则是这样的,首先给定一个数F ...

  7. luogu P3235 [HNOI2014]江南乐

    传送门 这题又是我什么时候做的(挠头) 首先是个和SG函数有关的博弈论,SG=0则先手必败.显然一堆石子就是一个游戏,而若干堆石子的SG值就是每堆SG的异或和,所以算出每堆石子SG就能知道答案 然后怎 ...

  8. P3235 [HNOI2014]江南乐

    $ \color{#0066ff}{ 题目描述 }$ 小A是一个名副其实的狂热的回合制游戏玩家.在获得了许多回合制游戏的世界级奖项之后,小A有一天突然想起了他小时候在江南玩过的一个回合制游戏. 游戏的 ...

  9. 【bzoj3576】 Hnoi2014—江南乐

    http://www.lydsy.com/JudgeOnline/problem.php?id=3576 (题目链接) 题意 给出一个数$F$,然后$n$堆石子,每次操作可以把一堆不少于$F$的石子分 ...

随机推荐

  1. 20155332 实验二 Java面向对象程序设计

    目录 一.单元测试和TDD 任务一:实现百分制成绩转成"优.良.中.及格.不及格"五级制成绩的功能 任务二:以TDD的方式研究学习StringBuffer 二.面向对象三要素:封装 ...

  2. 成都Uber优步司机奖励政策(4月10日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  3. 【LG3241】[HNOI2015]开店

    题面 洛谷 题解 20pts 直接暴力统计即可,复杂度\(O(NQ)\). 另20pts 我们考虑动态点分治. 怎么在原树上统计答案呢,我们对点\(x\), 预处理出其子节点数目\(s_0\),其子树 ...

  4. LOJ #2585. 「APIO2018」新家

    #2585. 「APIO2018」新家 https://loj.ac/problem/2585 分析: 线段树+二分. 首先看怎样数颜色,正常的时候,离线扫一遍右端点,每次只记录最右边的点,然后查询左 ...

  5. macOS 10.14 Mojave Apache设置:多个PHP版本

    [18/6/2018更新]由于Homebrew/php点击在2018年3月底被弃用,并将所有PHP公式移动到Homebrew/core,我们已经重新设计了我们的指南,使用这个新的水龙头. 如果您过去一 ...

  6. JMeter测试WebSocket的经验总结

    最近有一个微信聊天系统的项目需要性能测试,既然是测试微信聊天,肯定绕不开websocket接口的测试,首选工具是Jmeter,网上能搜到现成的方法,但是网上提供的jar包往往不是最新的,既然是用最新版 ...

  7. 接口自动化之接口工具选取(jmeter)

    jmeter进行接口测试,网上简易教程很多 其实关于HTTP接口测试的实现,网上还有很多其他工具诸如:http在线请求测试/谷歌插件postman/火狐插件等. 至于选择jmeter的原因,其实没有原 ...

  8. Java+Selenium 3.x 实现Web自动化 - Maven打包TestNG,利用jenkins执行测试

    1. Jenkins本地执行测试 or 服务器端执行测试 测试代码计划通过jenkins执行时,通过网上查询各种教程,大多数为本地执行测试,由此可见,本地执行是大多数人的选择. 经过探讨,最终决定采用 ...

  9. 安装文件报错error while loading shared libraries: libssl.so.6

    http://www.openssl.org/source/  这里下载http://www.openssl.org/source/openssl-1.0.0r.tar.gz 安装命令为:tar -z ...

  10. html5shiv 是一个针对 IE 浏览器的 HTML5 JavaScript 补丁,目的是让 IE 识别并支持 HTML5 元素。

    html5shiv 是一个针对 IE 浏览器的 HTML5 JavaScript 补丁,目的是让 IE 识别并支持 HTML5 元素. 各版本html5shiv.js CDN网址:https://ww ...