博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[BZOJ 4589] Hard Nim
阅读量:6466 次
发布时间:2019-06-23

本文共 1992 字,大约阅读时间需要 6 分钟。

Description

Claris 和 NanoApe 在玩石子游戏,他们有 \(n\) 堆石子,规则如下:

  1. Claris 和 NanoApe 两个人轮流拿石子,Claris 先拿。
  2. 每次只能从一堆中取若干个,可将一堆全取走,但不可不取,拿到最后 \(1\) 颗石子的人获胜。

不同的初始局面,决定了最终的获胜者,有些局面下先拿的 Claris 会赢,其余的局面 Claris 会负。

Claris 很好奇,如果这 \(n\) 堆石子满足每堆石子的初始数量是不超过 \(m\) 的质数,而且他们都会按照最优策略玩游戏,那么 NanoApe 能获胜的局面有多少种。

由于答案可能很大,你只需要给出答案对 \(10^9+7\) 取模的值。

Input

输入包含多组数据,每组数据一行两个正整数 \(n\)\(m\)

Output

每行一个整数表示答案。

Sample Input

3 74 13

Sample Output

6120

HINT

\(1\le n\le 10^9, 2\le m\le 50000\)

不超过 \(80\) 组数据。

Solution

NIM 游戏先手必胜的条件是每堆石子数的异或和为 \(0\)

相当于将一个只有质数次项的系数是 \(1\),其他项的系数是 \(0\)\(m\) 次多项式 \(fwt\) 异或卷积 \(n\) 次,最后输出常数项。

Code

#include 
const int mod = 1000000007, inv = 500000004;int n, m, nn, p[5135], np[50001], tot, a[65540], b[65540];void euler(int n) { for (int i = 2; i <= n; ++i) { if (!np[i]) p[++tot] = i; for (int j = 1; j <= tot && i * p[j] <= n; ++j) { np[i * p[j]] = 1; if (i % p[j] == 0) break; } }}void fwt(int *a, int f) { for (int i = 1; i < n; i <<= 1) for (int j = 0, r = i << 1; j < n; j += r) for (int k = 0; k < i; ++k) { int x = a[j + k], y = a[i + j + k]; a[j + k] = 1LL * (x + y) % mod, a[i + j + k] = 1LL * (x + mod - y) % mod; if (f == -1) a[j + k] = 1LL * a[j + k] * inv % mod, a[i + j + k] = 1LL * a[i + j + k] * inv % mod; }}int fastpow(int k) { for (; k; k >>= 1) { if (k & 1) for (int i = 0; i < n; ++i) b[i] = 1LL * b[i] * a[i] % mod; for (int i = 0; i < n; ++i) a[i] = 1LL * a[i] * a[i] % mod; } fwt(b, -1); return b[0];}int main() { euler(50000); while (~scanf("%d%d", &nn, &m)) { for (n = 1; n <= m; n <<= 1) {} for (int i = 0; i < n; ++i) a[i] = 0; for (int i = 1; i <= tot && p[i] <= m; ++i) a[p[i]] = 1; fwt(a, 1); for (int i = 0; i < n; ++i) b[i] = a[i]; printf("%d\n", fastpow(nn - 1)); } return 0;}

转载于:https://www.cnblogs.com/fly-in-milkyway/p/10329231.html

你可能感兴趣的文章
JAVA虚拟机05--面试必问之JVM原理
查看>>
Algs4-2.3.1如何切分数组
查看>>
uva 10815 - Andy's First Dictionary(快排、字符串)
查看>>
easyui的DataGrid的单元格添加ProgressBar进度条
查看>>
python处理中文文件格式
查看>>
英语网站
查看>>
峰Spring4学习(2)依赖注入的几种方式
查看>>
Linux学习: TCP粘包问题
查看>>
在Mac上安装vs code 以及运行asp.net5
查看>>
Network服务器
查看>>
android中json的序列化与反序列化
查看>>
观察者模式
查看>>
docker-3-常用命令(下)
查看>>
tex
查看>>
一些来不及整理的链接
查看>>
posix多线程有感--线程高级编程(线程堆栈)
查看>>
ROS初探--意义、基本模块
查看>>
❄️ 雪花降落
查看>>
数据结构_coprime_sequence(互质序列)
查看>>
Fiel类
查看>>