三模数 NTT,感觉不是很难写 $?$

代码借鉴的 https://www.cnblogs.com/Mychael/p/9297652.html

code:

#include <bits/stdc++.h>
#define SIZE 400005
#define ll long long
#define setIO(s) freopen(s".in","r",stdin)
using namespace std;
inline ll qpow(ll x,ll y,ll Mod)
{
ll re=1ll;
for(x%=Mod;y;y>>=1,x=x*x%Mod) if(y&1) re=re*x%Mod;
return re;
}
int pr[3]={469762049,998244353,1004535809};
struct poly
{
int G,Mod,A[SIZE];
void NTT(int *a,int len,int flag)
{
int i,j,k,mid;
for(i=k=0;i<len;++i)
{
if(i>k) swap(a[i],a[k]);
for(j=len>>1;(k^=j)<j;j>>=1);
}
for(mid=1;mid<len;mid<<=1)
{
int wn=qpow(G,(Mod-1)/(mid<<1),Mod);
if(flag==-1) wn=qpow(wn,Mod-2,Mod);
for(i=0;i<len;i+=mid<<1)
{
int w=1;
for(j=0;j<mid;++j)
{
int x=a[i+j], y=1ll*w*a[i+j+mid]%Mod;
a[i+j]=1ll*(x+y)%Mod, a[i+j+mid]=(x-y+Mod)%Mod;
w=1ll*w*wn%Mod;
}
}
}
if(flag==-1)
{
int rev=qpow(len,Mod-2,Mod);
for(i=0;i<len;++i) a[i]=1ll*a[i]*rev%Mod;
}
}
}ntt[3];
ll ans[SIZE];
int F[SIZE],G[SIZE],B[SIZE],deg1,deg2,deg,md;
ll INV(ll n,ll p) { return qpow(n%p, p-2,p); }
ll mul(ll a,ll b,ll p)
{
ll re=0;
for(;b;b>>=1,a=(a+a)%p) if(b&1) re=(re+a)%p;
return re;
}
void CRT()
{
deg=deg1+deg2;
ll a,b,c,t,k,M=1ll*pr[0]*pr[1];
ll inv1=INV(pr[1],pr[0]), inv0=INV(pr[0],pr[1]),inv3=INV(M%pr[2],pr[2]);
for(int i=0;i<=deg;++i)
{
a=ntt[0].A[i];
b=ntt[1].A[i];
c=ntt[2].A[i];
t=(mul(a*pr[1]%M,inv1,M)+mul(b*pr[0]%M,inv0,M))%M;
k=((c-t%pr[2])%pr[2]+pr[2])%pr[2]*inv3%pr[2];
ans[i]=((k%md)*(M%md)%md+t%md)%md;
}
}
void conv()
{
int n=1;
while(n<=(deg1+deg2)) n<<=1;
for(int u=0;u<=2;++u)
{
ntt[u].G=3;
ntt[u].Mod=pr[u];
for(int i=0;i<=deg1;++i) ntt[u].A[i]=F[i];
for(int i=0;i<=deg2;++i) B[i]=G[i];
for(int i=deg2+1;i<n;++i) B[i]=0;
ntt[u].NTT(ntt[u].A,n,1);
ntt[u].NTT(B,n,1);
for(int i=0;i<n;++i) ntt[u].A[i]=1ll*ntt[u].A[i]*B[i]%pr[u];
ntt[u].NTT(ntt[u].A,n,-1);
}
}
int main()
{
// setIO("input");
scanf("%d%d%d",&deg1,&deg2,&md);
for(int i=0;i<=deg1;++i) scanf("%d",&F[i]);
for(int i=0;i<=deg2;++i) scanf("%d",&G[i]);
conv();
CRT();
for(int i=0;i<=deg;++i) printf("%lld ",ans[i]);
return 0;
}

  

【洛谷P4245】 【模板】任意模数NTT的更多相关文章

  1. 洛谷 P4245 [模板]任意模数NTT —— 三模数NTT / 拆系数FFT(MTT)

    题目:https://www.luogu.org/problemnew/show/P4245 用三模数NTT做,需要注意时间和细节: 注意各种地方要取模!传入 upt() 里面的数一定要不超过2倍 m ...

  2. 洛谷.4245.[模板]任意模数NTT(MTT/三模数NTT)

    题目链接 三模数\(NTT\): 就是多模数\(NTT\)最后\(CRT\)一下...下面两篇讲的都挺明白的. https://blog.csdn.net/kscla/article/details/ ...

  3. [题解] Luogu P4245 [模板]任意模数NTT

    三模NTT 不会... 都0202年了,还有人写三模NTT啊... 讲一个好写点的做法吧: 首先取一个阀值\(w\),然后把多项式的每个系数写成\(aw + c(c < w)\)的形式,换句话说 ...

  4. 洛谷.3803.[模板]多项式乘法(NTT)

    题目链接:洛谷.LOJ. 为什么和那些差那么多啊.. 在这里记一下原根 Definition 阶 若\(a,p\)互质,且\(p>1\),我们称使\(a^n\equiv 1\ (mod\ p)\ ...

  5. 洛谷.4721.[模板]分治FFT(NTT)

    题目链接 换一下形式:\[f_i=\sum_{j=0}^{i-1}f_jg_{i-j}\] 然后就是分治FFT模板了\[f_{i,i\in[mid+1,r]}=\sum_{j=l}^{mid}f_jg ...

  6. 洛谷.4512.[模板]多项式除法(NTT)

    题目链接 多项式除法 & 取模 很神奇,记录一下. 只是主要部分,更详细的和其它内容看这吧. 给定一个\(n\)次多项式\(A(x)\)和\(m\)次多项式\(D(x)\),求\(deg(Q) ...

  7. [洛谷P4245]【模板】任意模数NTT

    题目大意:给你两个多项式$f(x)$和$g(x)$以及一个模数$p(p\leqslant10^9)$,求$f*g\pmod p$ 题解:任意模数$NTT$,最大的数为$p^2\times\max\{n ...

  8. 【模板】任意模数NTT

    题目描述: luogu 题解: 用$fft$水过(什么$ntt$我不知道). 众所周知,$fft$精度低,$ntt$处理范围小. 所以就有了任意模数ntt神奇$fft$! 意思是这样的.比如我要算$F ...

  9. 【知识总结】多项式全家桶(三)(任意模数NTT)

    经过两个月的咕咕,"多项式全家桶" 系列终于迎来了第三期--(雾) 上一篇:[知识总结]多项式全家桶(二)(ln和exp) 先膜拜(伏地膜)大恐龙的博客:任意模数 NTT (在页面 ...

  10. MTT:任意模数NTT

    MTT:任意模数NTT 概述 有时我们用FFT处理的数据很大,而模数可以分解为\(a\cdot 2^k+1\)的形式.次数用FFT精度不够,用NTT又找不到足够大的模数,于是MTT就应运而生了. MT ...

随机推荐

  1. argv和raw_input的区别

    argv是在一开始就要输入不输入程序会出现错误,raw_input是在运行之后进行输入.

  2. dom元素新增后不会触发事件

    <!DOCTYPE HTML> <html> <head> <title>checkbox设置只能单选</title> <script ...

  3. WITH AS学习

    一.WITH AS的含义     WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到.有的时候, ...

  4. Ubuntu 18.04 上使用xrdp远程桌面连接(Windows远程桌面连接)

    Ubuntu18.04设置#安装xrdpsudo apt-get install xrdp #安装vnc4serversudo apt-get install vnc4server tightvncs ...

  5. RabbitMQ实战-死信队列

    RabbitMQ死信队列 场景说明 代码实现 简单的Util 生产者 消费者 场景说明 场景: 当队列的消息未正常被消费时,如何解决? 消息被拒绝并且不再重新投递 消息超过有效期 队列超载 方案: 未 ...

  6. Part_three:Redis持久化存储

    redis持久化存储 Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失. 1.RD ...

  7. 卷积神经网络快速入门【基于TensorFlow】

    一.概述 卷积神经网络[Convolutional neural networks]里面最重要的构建单元是卷积层.神经元在第一个卷积层不是连接输入图片的每一个像素,只是连接它们感受野1的像素,以此类推 ...

  8. MySQL Lock--gap before rec insert intention waiting

    在事务插入数据过程中,为防止其他事务向索引上该位置插入数据,会在插入之前先申请插入意向范围锁,而如果申请插入意向范围锁被阻塞,则事务处于gap before rec insert intention ...

  9. Android笔记(三十八) Android中的数据存储——SharedPreferences

    SharedPreferences是Android提供的一种轻型的数据存储方法,其本质是基于xml文件存储的,内部数据以key-value的方式存储,通常用来存储一些简单的配置信息. SharedPr ...

  10. 微信小程序中使用云开发获取openid

    微信小程序获取openid 新建一个微信小程序项目 注意要注册一个自己的小程序账号,并有属于自己的appid 点击云开发按钮,自行填入开发环境名称 打开app.js,找到依赖环境 修改为刚才设置的环境 ...