r·2^k+1 r k g
3 1 1 2
5 1 2 2
17 1 4 3
97 3 5 5
193 3 6 5
257 1 8 3
7681 15 9 17
12289 3 12 11
40961 5 13 3
65537 1 16 3
786433 3 18 10
5767169 11 19 3
7340033 7 20 3
23068673 11 21 3
104857601 25 22 3
167772161 5 25 3
469762049 7 26 3
998244353 119 23 3
1004535809 479 21 3
2013265921 15 27 31
2281701377 17 27 3
3221225473 3 30 5
75161927681 35 31 3
77309411329 9 33 7
206158430209 3 36 22
2061584302081 15 37 7
2748779069441 5 39 3
6597069766657 3 41 5
39582418599937 9 42 5
79164837199873 9 43 5
263882790666241 15 44 7
1231453023109121 35 45 3
1337006139375617 19 46 3
3799912185593857 27 47 5
4222124650659841 15 48 19
7881299347898369 7 50 6
31525197391593473 7 52 3
180143985094819841 5 55 6
1945555039024054273 27 56 5
4179340454199820289 29 57 3

以上是一份NTT专用模数与原根的对照表……

然后从网上爬了一份NTT代码:http://www.cnblogs.com/candy99/p/6641972.html

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<algorithm>
  4. using namespace std;
  5. typedef long long ll;
  6. #define N ((1<<18)+5)
  7. #define MOD 1004535809ll
  8. ll Quick_Pow(ll a,ll p){
  9. if(p==0){
  10. return 1ll;
  11. }
  12. ll res=Quick_Pow(a,p>>1);
  13. res=res*res%MOD;
  14. if((p&1ll)==1ll){
  15. res=(a%MOD*res)%MOD;
  16. }
  17. return res;
  18. }
  19. struct NTT{
  20. int n,rev[N];
  21. ll g;
  22. void ini(int lim) {
  23. g=3;//1004535809,998244353的原根都是3
  24. n=1;
  25. int k=0;
  26. while(n<lim){
  27. n<<=1;
  28. ++k;
  29. }
  30. for(int i=0;i<n;++i){
  31. rev[i]=((rev[i>>1]>>1)|((i&1)<<(k-1)));
  32. }
  33. }
  34. void dft(ll a[],int DFT) {
  35. for(int i=0;i<n;++i){
  36. if(i<rev[i]){
  37. swap(a[i],a[rev[i]]);
  38. }
  39. }
  40. for(int l=2;l<=n;l<<=1){
  41. int m=l>>1;
  42. ll wn=Quick_Pow(g,DFT==1 ? (MOD-1ll)/(ll)l : MOD-1ll-(MOD-1ll)/(ll)l);
  43. for(int i=0;i<n;i+=l){
  44. ll w=1;
  45. for(int k=0;k<m;++k){
  46. ll t=w*a[i+k+m]%MOD;
  47. a[i+k+m]=(a[i+k]-t+MOD)%MOD;
  48. a[i+k]=(a[i+k]+t)%MOD;
  49. w=w*wn%MOD;
  50. }
  51. }
  52. }
  53. if(DFT==-1){
  54. ll inv=Quick_Pow(n,MOD-2ll);
  55. for(int i=0;i<n;++i){
  56. a[i]=a[i]*inv%MOD;
  57. }
  58. }
  59. }
  60. void mul(ll a[],ll b[],int len) {
  61. ini(len);
  62. dft(a,1);
  63. dft(b,1);
  64. for(int i=0;i<n;++i){
  65. a[i]=a[i]*b[i];
  66. }
  67. dft(a,-1);
  68. }
  69. }ntt;
  70. int len1,len2,len,c[N];
  71. ll a[N],b[N];
  72. char s1[N],s2[N];
  73. int main() {
  74. // freopen("ntt.in","r",stdin);
  75. while(scanf("%s%s",s1,s2)!=EOF){
  76. memset(c,0,sizeof(c));
  77. memset(a,0,sizeof(a));
  78. memset(b,0,sizeof(b));
  79. len1=strlen(s1);
  80. len2=strlen(s2);
  81. for(int i=0;i<len1;++i){
  82. a[i]=s1[len1-i-1]-'0';
  83. }
  84. for(int i=0;i<len2;++i){
  85. b[i]=s2[len2-i-1]-'0';
  86. }
  87. len=len1+len2-1;
  88. ntt.mul(a,b,len);
  89. for(int i=0;i<len;++i){
  90. c[i]=a[i];
  91. }
  92. for(int i=0;i<len;++i){
  93. c[i+1]+=c[i]/10;
  94. c[i]%=10;
  95. }
  96. // if(c[len]){
  97. // ++len;
  98. // }//两个数乘积的长度要么是A+B-1,要么是A+B。
  99. // for(int i=len-1;i>=0;--i){
  100. // printf("%d",c[i]);
  101. // }
  102. // puts("");
  103. for(int i=len;i>=0;--i){
  104. if(c[i]!=0 || i==0){
  105. for(int j=i;j>=0;--j){
  106. printf("%d",c[j]);
  107. }
  108. puts("");
  109. break;
  110. }
  111. }
  112. }
  113. return 0;
  114. }

【NTT】hdu1402 A * B Problem Plus的更多相关文章

  1. 【FFT】hdu1402 A * B Problem Plus

    FFT板子. 将大整数看作多项式,它们的乘积即多项式的乘积在x=10处的取值. #include<cstdio> #include<cmath> #include<cst ...

  2. 【BZOJ3489】A simple rmq problem(KD-Tree)

    [BZOJ3489]A simple rmq problem(KD-Tree) 题面 BZOJ 题解 直接做肯定不好做,首先我们知道我们是一个二维平面数点,但是限制区间只能出现一次很不好办,那么我们给 ...

  3. 【CF903G】Yet Another Maxflow Problem 线段树

    [CF903G]Yet Another Maxflow Problem 题意:一张图分为两部分,左边有n个点A,右边有m个点B,所有Ai->Ai+1有边,所有Bi->Bi+1有边,某些Ai ...

  4. 【BZOJ3489】A simple rmq problem

    [BZOJ3489]A simple rmq problem 题面 bzoj 题解 这个题不强制在线的话随便做啊... 考虑强制在线时怎么搞 预处理出一个位置上一个出现的相同数的位置\(pre\)与下 ...

  5. 【BZOJ3489】A simple rmq problem kd-tree

    [BZOJ3489]A simple rmq problem Description 因为是OJ上的题,就简单点好了.给出一个长度为n的序列,给出M个询问:在[l,r]之间找到一个在这个区间里只出现过 ...

  6. 【题解】CF986E Prince's Problem(树上差分+数论性质)

    [题解]CF986E Prince's Problem(树上差分+数论性质) 题目大意: 给定你一棵树,有点权\(val_i\le 10^7\).现在有\(m\)组询问给定参数\(x,y,w\)问你对 ...

  7. 【动态规划】Codeforces 706C Hard problem

    题目链接: http://codeforces.com/contest/706/problem/C 题目大意: n(2 ≤ n ≤ 100 000)个字符串(长度不超过100000),翻转费用为Ci( ...

  8. 【BZOJ】1700: [Usaco2007 Jan]Problem Solving 解题

    [题意]给定n道题,每月末发放工资m,要求从1解到n,每道题需要在当月初付费ai,下月初付费bi,多道题可以安排在同月,求最少月数. [算法]DP [题解]参考自:[bzoj1700]Problem ...

  9. 【NTT】loj#6261. 一个人的高三楼

    去年看过t老师写这题博客:以为是道神仙题 题目大意 求一个数列的$k$次前缀和.$n\le 10^5$. 题目分析 [计数]cf223C. Partial Sums 加强版.注意到最后的式子是$f_i ...

随机推荐

  1. .net WebAPI返回xml、json格式

    WebAPI返回xml.json格式简单示例 using System.Net.Http.Formatting; public class TestController : ApiController ...

  2. Sketch VS Photoshop

    参考:http://mp.weixin.qq.com/s?__biz=MjM5NTQ5MjIyMA==&mid=217309554&idx=4&sn=4d6a5239ca813 ...

  3. hdu1002 A + B Problem II(大数题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1002 A + B Problem II Time Limit: 2000/1000 MS (Java/ ...

  4. JVM在遇到OOM(OutOfMemoryError)时生成Dump文件

    方法一: 命令:jmap -dump:format=b,file=heap.bin file:保存路径及文件名pid:进程编号(windows通过任务管理器查看,linux通过ps aux查看) du ...

  5. js删除数组中重复的元素

    1.方法一 将数组逐个搬到另一个数组中,当遇到重复元素时,不移动,若元素不重复则移动到新数组中 function unique(arr){ var len = arr.length; var resu ...

  6. Fiddler抓取HTTPS协议

    HTTPS协议握手过程: 1,客户端明文请求,把自己支持的非对称加密算法(用于使用CA证书公钥加密计算生成协商密钥的随机数per_master).对称加密算法(用于以后使用协商密钥加密传输内容).验证 ...

  7. xcode 配置系统环境变量 Preporocessing 预编译宏的另一种写法, 系统的DEBUG 由来

    在某些项目中看到一些环境变量类似宏的东西 比如叫ENVIRONMENT, 但发现还找不到具体这个宏是什么值, 那是因为他实在Preprocessing里配置了这个宏的值, 他能配置debug/rele ...

  8. SAE如何使用Git

    了解Git及远程git仓库 请先看博文<Git入门及上传项目到github中>,弄懂了之后我相信我下面说的就相当于废话了. SAE的git远程仓库就相当于github. 向SAE的远程仓库 ...

  9. IoT之车联网

    一. 背景 这是一个笔者在实习公司策划的关于车联网的小项目,也是笔者参加某竞赛的作品<基于云平台的车内滞留儿童状况监测与处理>,本项目旨在为因各种原因导致儿童滞留车内热死.闷死的社会性事件 ...

  10. 破解 myeclipse 2014 professional,步骤很重要

    网易 博客 GACHA-动漫萌妹汇集地 LOFTER-最美图片社交 印像派-我的照片书 这些小语种最有前途,免费学 注册登录  加关注     日志     Windows下解决PostgreSQL8 ...