博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NTT学习笔记
阅读量:6002 次
发布时间:2019-06-20

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

\(FFT\)相对应的,把单位根换成了原根,把共轭复数换成了原根的逆元,最后输出的时候记得乘以原\(N\)的逆元即可.

#include 
using namespace std;#define LL long long const int MAXN = 3 * 1e6 + 10, P = 998244353, G = 3; LL a[MAXN], b[MAXN];int N, M, limit = 1, L, r[MAXN], Gi;inline LL fastpow(LL a, LL k) { LL base = 1; while(k) { if(k & 1) base = (base * a ) % P; a = (a * a) % P; k >>= 1; } return base % P;}inline void NTT(LL *A, int type) { for (int i = 0; i < limit; i++) { if(i < r[i]) swap(A[i], A[r[i]]); } for (int mid = 1; mid < limit; mid <<= 1) { LL Wn = fastpow (type == 1 ? G : Gi , (P - 1) / (mid << 1)); for(int j = 0; j < limit; j += (mid << 1)) { LL w = 1; for (int k = 0; k < mid; k++, w = (w * Wn) % P) { int x = A[j + k], y = (w * A[j + k + mid]) % P; A[j + k] = (x + y) % P; A[j + k + mid] = (x - y + P) % P; } } }}int main () { Gi = fastpow (G, P - 2); cin >> N >> M; for (int i = 0; i <= N; i++) {cin >> a[i]; a[i] = (a[i] + P) % P;} for (int i = 0; i <= M; i++) {cin >> b[i]; b[i] = (b[i] + P) % P;} while (limit <= N + M) limit <<= 1, L++; for (int i = 0; i < limit; i++) r[i] = (r[i >> 1] >> 1) | ((i & 1) << (L - 1)); NTT (a, 1); NTT (b, 1); for (int i = 0; i < limit; i++) a[i] = (a[i] * b[i]) % P; NTT (a, -1); LL inv = fastpow (limit, P - 2); for (int i = 0; i <= N + M; i++) { printf ("%d ", (a[i] * inv) % P); } return 0;}

转载于:https://www.cnblogs.com/maomao9173/p/10494092.html

你可能感兴趣的文章
【PMP认证考试之个人总结】第 5 章 项目时间管理
查看>>
Chair:支付宝前端团队推出的Node.js Web框架
查看>>
《Total Commander:万能文件管理器》——第3.8节.后续更新
查看>>
BSD vi/vim 命令大全(下)[转]
查看>>
css3中变形与动画(一)
查看>>
[XMove-自主设计的体感解决方案] 系统综述
查看>>
设计模式 ( 十五 ) 中介者模式Mediator(对象行为型)
查看>>
【LINUX学习】磁盘分割之建立primary和logical 分区
查看>>
【YUM】第三方yum源rpmforge
查看>>
IOS(CGGeometry)几何类方法总结
查看>>
才知道系列之GroupOn
查看>>
⑲云上场景:超级减肥王,基于OSS的高效存储实践
查看>>
linux kswapd浅析
查看>>
变更 Linux、Ubuntu 时区、时间
查看>>
高仿QQ空间 侧滑Menu效果且换肤功能《IT蓝豹》
查看>>
mac的git的21个客户端
查看>>
Spring Cloud自定义引导属性源
查看>>
[共通]手机端网页开发问题及解决方法整理
查看>>
我的友情链接
查看>>
${basePath}
查看>>