三模数 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. Dubbo快速入门 五

    5. Dubbo注解版 之前在dubbo配置文件显式编写内容提供者和消费者,官方还提供了了一种注解方式,接下来改造项目 1.服务提供方 dubbo配置文件 将之前手动申明注释掉,添加<dubbo ...

  2. Debian 下忘记root密码的特殊修改方式

    当系统开机进入 grub页面时,在启动条目上按下键盘的 e 进入编辑 找到 linux 开头的一行,类似下面这样 linux /boot/vmlinux-4.9.0.8-amd64 root=/dev ...

  3. 玩转Spring全家桶笔记 02 那些好用的连接池HikariCP

    1.前言 简单了解一下来自日本的一个新起之秀连接池---HikariCP github:https://github.com/brettwooldridge/HikariCP 2.HikariCP为什 ...

  4. C#解压、压缩高级用法

    压缩:(可以吧要排除的文件去掉) /// <summary> /// 压缩文件夹 /// </summary> /// <param name="folder& ...

  5. Qt 利用飞机图片画五边形

    最近练习Qt,需要一个飞机在屏幕上画五边形.虽然达到的效果不是非常的理想,但是勉强还是达到了效果,欢迎大家指正.用到的飞机图片如下. 第一步:初始化,在构造函数里面,把图片向左旋转18° );ui.l ...

  6. Typescript项目注意点和基本类型介绍

    从typescript源文件到执行的过程 执行者 步骤 说明 TSC 1. TypeScript Source -> TypeScript AST TSC将ts文件转为TS AST(abstra ...

  7. MySQL Index--InnoDB引擎的主键索引

    查看表主键信息 ## 查看表主键信息 SELECT t.TABLE_NAME, t.CONSTRAINT_TYPE, c.COLUMN_NAME, c.ORDINAL_POSITION FROM IN ...

  8. Linux命令cut

    原文 cut 文件内容查看 显示行中的指定部分,删除文件中指定字段 显示文件的内容,类似于下的type命令. 说明 该命令有两项功能,其一是用来显示文件的内容,它依次读取由参数file所指明的文件,将 ...

  9. 解决linux下创建用户时出现 Creating mailbox file: 文件已存在

    原来linux下添加用户后,会在系统里自动加一个邮箱(系统邮箱),路径是:/var/spool/mail/用户名.      可以直接用命令#rm -rf /var/spool/mail/用户名    ...

  10. array_pop

    array_pop() 函数删除数组中的最后一个元素,返回数组的最后一个值.如果数组是空的,或者非数组,将返回 NULL. <?php$a=["red","gree ...