博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
大数乘法
阅读量:5324 次
发布时间:2019-06-14

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

1 /*  2   题意:大数乘法NTT  3   题解:FNT  4   时间:2018.07.30  5 */  6   7 #include 
8 using namespace std; 9 10 typedef long long LL; 11 const int MAXN = 100005; 12 const LL MOD7 = 1e9+7; 13 const LL MOD717 = 998244353LL; // 7*17*2^23 +1 14 const LL MOD479 = (479LL<<21) + 1; // 1004535809 15 16 inline LL Add(LL a,LL b, LL P) { a+=b;if(a>=P) a-=P;return a; } 17 inline LL Del(LL a,LL b, LL P) { a-=b;if(a<0LL) a+=P;return a; } 18 inline LL Mul(LL a,LL b, LL P) { a=a*b%P;return a; } 19 20 LL Pow(LL a,LL b, LL P) 21 { 22 LL res=1LL; 23 LL ans=a%P; 24 while (b) 25 { 26 if (b&1) res=res*ans%P; 27 ans=ans*ans%P; 28 b>>=1; 29 } 30 return res; 31 } 32 33 34 struct NTT 35 { 36 int L,l,rev[MAXN*20]; 37 38 int pre(int n) 39 { 40 for (l=0;(1<
> 1] >> 1 | (i&1) << (l-1); 44 return L; 45 } 46 47 void dft(LL *a, LL P) 48 { 49 //蝴蝶操作交换每个系数到需要的位置上 50 for (int i=0;i
rev[i]) swap(a[i],a[rev[i]]); 53 } 54 // 从下向上计算,i枚举宽度,第一层不需要计算,从步长为2的开始 55 // m 是步长 为宽度的一半 56 // wn 是第n层的单位根 (wn)^n %P = 1, 3是模P的原根, L | (P-1) 保证原根满足FFT的单位根的性质 57 // j 枚举每个宽度的开始位置 58 // k 枚举每个宽度内的位置 59 // w 为每次蝴蝶操作的系数 60 // 每次操作的两个位置为a[j+k] 和a[j+k+m] 并且a[j+k] = a[j+k] + w*a[j+k+m] a[j+k+m] = a[j+k] - w*a[j+k+m] 61 for (int i=2;i<=L;i<<=1) 62 { 63 int m=(i>>1); 64 LL wn = Pow(3, (P-1)/i, P); 65 // printf("wn=%lld\n",wn); 66 for (int j=0;j
a) 96 { 97 for (auto it=a.begin();it!=a.end();++it) 98 { 99 printf("%lld ",*it);100 }101 puts("");102 }103 104 105 vector
Mul(vector
a, vector
b, LL P)106 {107 int n = a.size() + b.size() - 1;108 // printf("n=%d\n",n);109 int L = ntt.pre(n);110 // printf("L=%d\n",L);111 vector
c;112 // printf("L=%d\n",L);113 114 if (1LL * a.size()*b.size() <= (a.size() + b.size())*20LL)115 {116 c.resize(n);117 for (int i=0;i
a,b,c;146 vector
ans;147 148 149 150 151 int main()152 {153 #ifndef ONLINE_JUDGE154 freopen("test.txt","r",stdin);155 #endif // ONLINE_JUDGE156 while (scanf("%s%s",sa,sb)!=-1)157 {158 a.clear();b.clear();c.clear();ans.clear();159 int i,j,n;160 char *s;161 s=sa;162 n = strlen(s);163 for (j=0;j
=j;--i) a.push_back(s[i]-'0');166 s = sb;167 n=strlen(s);168 for (j=0;j
=j;--i) b.push_back(s[i]-'0');171 c = Mul(a,b,MOD717);172 LL tmp,ci=0;173 for (i=0;i
0 && ans[i]==0;--i,ans.pop_back());186 reverse(ans.begin(),ans.end());187 for (auto it=ans.begin();it!=ans.end();++it)188 {189 printf("%lld",*it);190 }191 printf("\n");192 }193 return 0;194 }

 

转载于:https://www.cnblogs.com/LeeSongt/p/9389615.html

你可能感兴趣的文章
IOS开发学习笔记026-UITableView的使用
查看>>
Confluence配置数据库
查看>>
Java锁机制(一)synchronized
查看>>
002.文件删除功能
查看>>
[转载]电脑小绝技
查看>>
windos系统定时执行批处理文件(bat文件)
查看>>
06-redis主从
查看>>
linux下面桌面的安装
查看>>
thinkphp如何实现伪静态
查看>>
作业引擎quartz.net --- 监听链
查看>>
iframe传参数
查看>>
BZOJ 2243: [SDOI2011]染色( 树链剖分 )
查看>>
BZOJ 1925: [Sdoi2010]地精部落( dp )
查看>>
c++中的string常用函数用法总结!
查看>>
C语言学习记录_2019.02.06
查看>>
界面交互之支付宝生活圈pk微信朋友圈
查看>>
字符串比较
查看>>
epoll 技术(转)
查看>>
<转>Shell脚本相关
查看>>
使用FreeMarker加载远程主机上模板文件,比如FTP,Hadoop等(转载)
查看>>