【LG3235】 [HNOI2014]江南乐

时间:2022-08-30 02:25:01

题目描述

给出\(n\)堆石子, 每次可以选择将大于某个数\(f\)一堆平均分成多个堆, 最后不能操作的失败。

题解

10pts

直接爆搜即可。

70pts

像我们对这类题目的常规操作那样,将一整个局面分为几个子游戏,然后异或起来求答案。

注意到我们现将一堆\(m\)分为\(i\)堆,那么会分成\(\lfloor \frac mi\rfloor * i\)堆大小为\(\lfloor \frac mi\rfloor\)的,\(m - \lfloor \frac mi\rfloor * i\)堆大小为\(\lfloor \frac mi\rfloor+1\)的,

我们直接暴力求每个状态的\(SG\)就好了,复杂度\(O(T\)值域\(^2)\)。

100pts

观察到一种拆分的方案\(j,j,j...j,j+1,j+1...j+1\),

在异或的过程中\(SG(j)\bigoplus SG(j)=0\),\(SG(j+1)\bigoplus SG(j+1)=0\),

那么只要考虑有奇数还是偶数个\(j\),\(j+1\)即可。

但是这样还是不够的, 我们自然而然的想到, 如果将石子堆划分为\(i\)堆 或者是\(k\)堆而且 \(\lfloor\frac{m}{i}\rfloor=\lfloor\frac{m}{k}\rfloor\)

它们的后继状态都是\(SG(\lfloor\frac{m}{i}\rfloor)\)

或者是 \(SG(\lfloor\frac{m}{i}\rfloor+1)\),

它们对答案的贡献可能是相同的, 根据上一段的论述, 这取决于 \(\lfloor\frac{m}{i}\rfloor\times i\)

和 \(\lfloor \frac{x}{i}\rfloor\times i\)的奇偶性。

如果我们手推一下, 就会发现如果 $$\lfloor\frac{m}{i}\rfloor=\lfloor\frac{m}{i+1}\rfloor=\lfloor\frac{m}{i+2}\rfloor=\cdots$$

那么\(i\)和\(i+1\)对答案的贡献是相同的, \(i+1\)和\(i+2\)堆答案的贡献相同,,相同的状态我们只需要计算一次,对于\(\frac{m}{i}\)相同的所有\(i\),我们只需要计算最小的\(i\)和\(i+1\)即可。

然后我们对这个进行数论分块即可。

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
inline int gi() {
register int data = 0, w = 1;
register char ch = 0;
while (!isdigit(ch) && ch != '-') ch = getchar();
if (ch == '-') w = -1, ch = getchar();
while (isdigit(ch)) data = 10 * data + ch - '0', ch = getchar();
return w * data;
} const int MAX_N = 1e5 + 5;
int SG[MAX_N], vis[MAX_N], T, F;
int dfs(int x) {
if (x < F) return 0;
if (~SG[x]) return SG[x];
for (int l = 2, r; l <= x; l = r + 1) {
r = (x / (x / l));
for (int j = l; j <= min(l + 1, r); j++) {
int a = x % j, b = x / j, c = j - x % j, s = 0;
if (a & 1) s ^= dfs(b + 1);
if (c & 1) s ^= dfs(b);
vis[s] = x;
}
}
for (int i = 0;; i++) if (vis[i] != x) return SG[x] = i;
} int main() {
#ifndef ONLINE_JUDGE
freopen("cpp.in", "r", stdin);
#endif
memset(SG, -1, sizeof(SG));
T = gi(), F = gi();
while (T--) {
int n = gi(), ans = 0;
for (int i = 1; i <= n; i++) ans ^= dfs(gi());
printf("%d ", (bool)ans);
}
return 0;
}

【LG3235】 [HNOI2014]江南乐的更多相关文章

  1. bzoj 3576&lbrack;Hnoi2014&rsqb;江南乐 sg函数&plus;分块预处理

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

  2. 洛谷 P3235 &lbrack;HNOI2014&rsqb;江南乐 解题报告

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

  3. bzoj3576&colon; &lbrack;Hnoi2014&rsqb;江南乐

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

  4. &lbrack;HNOI2014&rsqb;江南乐

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

  5. 洛谷P3235 &lbrack;HNOI2014&rsqb;江南乐&lpar;Multi-SG&rpar;

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

  6. luogu P3235 &lbrack;HNOI2014&rsqb;江南乐

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

  7. 【BZOJ】3576&colon; &lbrack;Hnoi2014&rsqb;江南乐

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3576 很显然,这是一个multi-nim游戏. 注意:1.一个点的SG值就是一个不等于它的 ...

  8. 【bzoj3576】 Hnoi2014—江南乐

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

  9. luoguP3235 &lbrack;HNOI2014&rsqb;江南乐 数论分块 &plus; 博弈论

    感觉其实很水? 题目就是一个Multi SG游戏,只需要预处理出所有的\(sg\)值即可\(O(Tn)\)计算 对于计算\(sg[n]\)而言,显然我们可以枚举划分了\(x\)堆来查看后继状态 那么, ...

随机推荐

  1. 使用canal分析binlog&lpar;一&rpar; 入门

    canal介绍 canal是应阿里巴巴存在杭州和美国的双机房部署,存在跨机房同步的业务需求而提出的.早期,阿里巴巴B2B公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求.不过早期的数据库同步 ...

  2. ASP&period;NET 5新特性

    近期微软发布了ASP.NET 5.0,本次发布的新特性需求源于大量用户的反馈和需求,例如灵活的跨平台运行时和自主部署能力使ASP.NET应用不再受限于IIS.Cloud-ready环境配置降低了云端部 ...

  3. Android NFC标签 开发深度解析 触碰的艺术

    有几天没有更新博客了,不过本篇却准备了许久,希望能带给每一位开发者最简单高效的学习方式.废话到此为止,下面开始正文. NFC(Near Field Communication,近场通信)是一种数据传输 ...

  4. Scripting Java &num;3:Groovy与invokedynamic

    只需看看今天Groovy语言实现机制.在此之前,是第一个推倒静态类型与动态类型语言在实现上面的一些差异. 静态类型 vs. 动态类型 看以下这个简单的栗子. def addtwo(a, b) { re ...

  5. java课程设计---计算器(201521123020 邱伟达)

    1.团队课程设计博客链接 http://www.cnblogs.com/br0823/p/7064407.html 2.个人负责模板或任务说明 1.初始化按键 2.实现加减乘除开方乘方等运算 3.每个 ...

  6. Java程序设计的第一次作业1

  7. 微信自用高性能通用key-value组件MMKV已开源!

    1.MMKV简介 腾讯微信团队于2018年9月底宣布开源 MMKV ,这是基于 mmap 内存映射的 key-value 组件,底层序列化/反序列化使用 protobuf 实现,主打高性能和稳定性.近 ...

  8. Class&lt&semi;&quest;&gt&semi; getClass&lpar;&rpar;

    getClass()方法属于Object的一部分,它将产生对象的类,并且在打印该类时,可以看到该类类型的编码字符串,前导"["表示这是一个后满紧随的类型的数组,而紧随的" ...

  9. Reactor 3 学习笔记&lpar;1&rpar;

    Reactor 3 与之前学习的RxJava是同一类(反应式编程)框架,基本概念大致差不多,简单记录一下: Reactor 3 利用了java 8中的CompletableFuture.Stream. ...

  10. 开关Windows休眠功能

    在windows休眠的时候会把内存里的数据缓存到硬盘的C:/Hiberfil.sys文件,万一断电能够从中恢复状态,然而这对SSD硬盘损耗很大,如果没必要还是关了吧: 关闭: powercfg -h ...