Description

题库链接

两人玩 \(nim\) 游戏,\(n\) 堆石子,每堆石子初始数量是不超过 \(m\) 的质数,那么后手必胜的方案有多少种。对 \(10^9+7\) 取模。

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

Solution

我们记多项式 \(A(x)\) ,对于 \(x_i\) 若 \(i\leq m\) 且 \(i\) 为质数,那么 \(x_i\) 的系数为 \(1\) ,其余情况系数为 \(0\) 。

显然当 \(n=2\) 时,令多项式

\[C(x)=A(x)\oplus A(x)\]

其中 \(\oplus\) 为按位异或。那么 \(c_0\) 即为答案。

更多地, \(C(x)=A^n(x)\) ,那么 \(c_0\) 就是 \(n\) 堆石子的方案数。

\(FWT\) 乱搞一下即可。

Code

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int mod = 1e9+7, N = 50000;
  4. int isprime[N+5], prime[N+5], tot, n, m, len, inv2;
  5. int f[N*2+5], a[N*2+5];
  6. int quick_pow(int a, int b) {
  7. int ans = 1;
  8. while (b) {
  9. if (b&1) ans = 1ll*ans*a%mod;
  10. b >>= 1, a = 1ll*a*a%mod;
  11. }
  12. return ans;
  13. }
  14. void get_prime() {
  15. memset(isprime, 1, sizeof(isprime)); isprime[1] = 0;
  16. for (int i = 2; i <= N; i++) {
  17. if (isprime[i]) prime[++tot] = i;
  18. for (int j = 1; j <= tot && i*prime[j] <= N; j++) {
  19. isprime[i*prime[j]] = 0;
  20. if (i%prime[j] == 0) break;
  21. }
  22. }
  23. }
  24. void FWT(int *A, int o) {
  25. for (int i = 1; i < len; i <<= 1)
  26. for (int j = 0; j < len; j += (i<<1))
  27. for (int k = 0; k < i; k++) {
  28. int x = A[k+j], y = A[k+j+i];
  29. A[k+j] = (x+y)%mod, A[k+j+i] = (x-y+mod)%mod;
  30. if (o == -1) A[k+j] = 1ll*A[k+j]*inv2%mod, A[k+j+i] = 1ll*A[k+j+i]*inv2%mod;
  31. }
  32. }
  33. void work() {
  34. inv2 = quick_pow(2, mod-2);
  35. get_prime();
  36. while (~scanf("%d%d", &n, &m)) {
  37. memset(f, 0, sizeof(f));
  38. for (int i = 1; i <= tot && prime[i] <= m; i++) f[prime[i]] = 1;
  39. memset(a, 0, sizeof(a)); a[0] = 1;
  40. for (len = 1; len <= m; len <<= 1);
  41. FWT(a, 1), FWT(f, 1);
  42. while (n) {
  43. if (n&1) for (int i = 0; i < len; i++) a[i] = 1ll*a[i]*f[i]%mod;
  44. for (int i = 0; i < len; i++) f[i] = 1ll*f[i]*f[i]%mod;
  45. n >>= 1;
  46. }
  47. FWT(a, -1); printf("%d\n", a[0]);
  48. }
  49. }
  50. int main() {work(); return 0; }

[BZOJ 4589]Hard Nim的更多相关文章

  1. FWT [BZOJ 4589:Hard Nim]

    4589: Hard Nim Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 275  Solved: 152[Submit][Status][Disc ...

  2. BZOJ 4589 Hard Nim(FWT+博弈论+快速幂)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4589 [题目大意] 有n堆石子,每堆都是m以内的质数,请问后手必胜的局面有几种 [题解 ...

  3. bzoj 4589 Hard Nim——FWT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4589 一开始异或和为0的话先手必败.有 n 堆,每堆可以填那些数,求最后异或和为0的方案数, ...

  4. BZOJ 4589 Hard Nim(FWT加速DP)

    题目链接  Hard Nim 设$f[i][j]$表示前$i$个数结束后异或和为$j$的方案数 那么$f[i][j] = f[i-1][j$ $\hat{}$ $k]$,满足$k$为不大于$m$的质数 ...

  5. bzoj 4589 Hard Nim —— FWT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4589 先手必败,是一开始所有石子的异或和为0: 生成函数 (xpri[1] + xpri[2 ...

  6. bzoj 4589: Hard Nim【线性筛+FWT+快速幂】

    T了两次之后我突然意识到转成fwt形式之后,直接快速幂每次乘一下最后再逆回来即可,并不需要没此次都正反转化一次-- 就是根据nim的性质,先手必输是所有堆个数异或和为0,也就变成了一个裸的板子 #in ...

  7. BZOJ.4589.Hard Nim(FWT)

    题目链接 FWT 题意即,从所有小于\(m\)的质数中,选出\(n\)个数,使它们异或和为\(0\)的方案数. 令\(G(x)=[x是质数]\),其实就是对\(G(x)\)做\(n\)次异或卷积后得到 ...

  8. BZOJ 4589 Hard Nim ——FWT

    [题目分析] 位运算下的卷积问题. FWT直接做. 但还是不太民白,发明者要承担泽任的. [代码] #include <cstdio> #include <cstring> # ...

  9. 【bzoj 4589】Hard Nim

    题目 根据我为数不多的博弈知识我发现需要求多少种方案使得异或和为\(0\) 非常显然就是构造出那个质数多项式\(F\),答案就是\(F^n(0)\),当然这里是异或卷积 于是美滋滋的敲上去一个多项式快 ...

随机推荐

  1. python全栈学习--day9(函数初始)

    Python 函数 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也 ...

  2. 20162328蔡文琛week05

    学号 20162328 <程序设计与数据结构>第X周学习总结 教材学习内容总结 面向对象程序设计的核心是类的定义,它代表定义了状态和行为的对象. 变量的作用域依赖于变量声明的位置,作用域决 ...

  3. (转)如何在Eclipse中查看JDK类库的源代码

    在Eclipse中查看JDK类库的源代码!!! 设置: 1.点 “window”-> "Preferences" -> "Java" -> & ...

  4. 201421123042 《Java程序设计》第5周学习总结

    1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 接口 Comparable Arrays.sort -has a Lambda表达式 1.2尝试使用思维导图将这些关键词组织起来 ...

  5. springboot字符集乱码

    入门扫盲:https://www.2cto.com/database/201701/584442.html 1.修改springweb类bug 2.数据库连接配置 3.数据库字符集 https://w ...

  6. kubernetes进阶(05)kubernetes的命令

    在Kubernetes中,Node.Pod.Replication Controller.Service等概念都可以看作一种资源对象,通过Kubernetes提供的Kubectl工具或者API调用进行 ...

  7. SSO的全方位解决方案 - Kerberos协议(RFC 1510)

    一.桌面SSO和WEB-SSO的局限性 前面我们的解决方案(桌面SSO和WEB-SSO)都有一个共性:要想将一个应用集成到我们的SSO解决方案中,或多或少的需要修改应用程序. Web应用需要配置一个我 ...

  8. Spring Security入门(3-2)Spring Security对接用户的权限系统

    源文链接,多谢作者的分享: http://www.360doc.com/content/14/0727/16/18637323_397445724.shtml 1.原生的spring-security ...

  9. QT5.5与MYSQL5.6数据库连接的具体方法与实现

    由于毕设需要用到QT读取数据库中的数据,并将数据保存至数据库中.花了一天的时间,总算实现了从QT中读取数据库中的数据.网上相关资料很多,但是写得不是很全,中间出现了一些问题,解决起来比较麻烦.所以本文 ...

  10. vscode调试适配器已意外终止

    出现这个错误了,找半天没找到办法.师兄支了一招: 把图中红圈部分删掉! 这是个旧的配置文件 ,你删掉它(反正一直报错误,也用不成了!).然后你调试一个文件,它会重新自动添加新的配置文件.