今天的A题。裸的ntt,但我不会,于是白送了50分。

于是跑来学一下ntt。

题面非常easy。就懒得贴了,那不是我要说的重点。

重点是NTT,也称高速数论变换。

在非常多问题中,我们可能会遇到在模意义下的多项式乘法问题,这时传统的高速傅里叶变换可能就无法满足要求,这时候高速数论变换就派上了用场。

考虑高速傅里叶变换的实现,利用单位复根的特殊性质来降低运算。而利用的。就是dft变换的循环卷积特性。

于是考虑在模意义下相同具有循环卷积特性的东西。

考虑在模p意义下(p为特定的质数,满足p=c∗2n+1)

我们令p的一个原根为g,于是类比fft,我们的单位根为gp−1n,然后其他的处理都类比fft。

UPD:这是uoj34的代码

#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef double db; const int inf=0x3f3f3f3f; int getint()
{
int f=1,g=0;char c=getchar();
while(c<'0' || c>'9'){if(c=='-')f=-1;c=getchar();}
while(c>='0' && c<='9')g=(g<<3)+(g<<1)+c-'0',c=getchar();
return f*g;
} const int maxn=300005;
const int mod=998244353; const int G=3; int a[maxn];
int b[maxn];
int c[maxn];
int n,m;
int rev[maxn];
int N;
int len;
int inv; int power(ll x,ll y)
{
ll res=1ll;
for(;y;y>>=1,x=(x*x)%mod)
{
if(y&1)res=(res*x)%mod;
}
return res;
} void init()
{
while((n+m)>=(1<<len))len++;
N=(1<<len);
inv=power(N,mod-2);
for(int i=0;i<N;i++)
{
int pos=0;
int temp=i;
for(int j=1;j<=len;j++)
{
pos<<=1;pos |= temp&1;temp>>=1;
}
rev[i]=pos;
}
} void ntt(int *a,int n,int re)
{
for(int i=0;i<n;i++)
{
if(rev[i]>i)
{
swap(a[i],a[rev[i]]);
}
}
for(int i=2;i<=n;i<<=1)
{
int mid=i>>1; int wn=power(G,(mod-1)/i);
if(re) wn=power(wn,(mod-2));
for(int j=0;j<n;j+=i)
{
int w=1;
for(int k=0;k<mid;k++)
{
int temp1=a[j+k];
int temp2=(ll)a[j+k+mid]*w%mod;
a[j+k]=(temp1+temp2);if(a[j+k]>=mod)a[j+k]-=mod;
a[j+k+mid]=(temp1-temp2);if(a[j+k+mid]<0)a[j+k+mid]+=mod;
w=(ll)w*wn%mod;
}
}
}
if(re)
{
for(int i=0;i<n;i++)
{
a[i]=(ll)a[i]*inv%mod;
}
}
} int main()
{
n=getint();
m=getint(); for(int i=0;i<=n;i++)
{
a[i]=getint();
}
for(int i=0;i<=m;i++)
{
b[i]=getint();
} init(); ntt(a,N,0);
ntt(b,N,0);
for(int i=0;i<=N;i++)
{
c[i]=(ll)a[i]*b[i]%mod;
}
ntt(c,N,1);
for(int i=0;i<=n+m;i++)
{
printf("%d%c",c[i]," \n"[i==n+m]);
} return 0;
}

高速数论变换(NTT)的更多相关文章

  1. 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】

    原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ...

  2. 从傅里叶变换(FFT)到数论变换(NTT)

    FFT可以用来计算多项式乘法,但是复数的运算中含有大量的浮点数,精度较低.对于只有整数参与运算的多项式,有时,\(\text{NTT(Number-Theoretic Transform)}\)会是更 ...

  3. 【算法】快速数论变换(NTT)初探

    [简介] 快速傅里叶变换(FFT)运用了单位复根的性质减少了运算,但是每个复数系数的实部和虚部是一个余弦和正弦函数,因此系数都是浮点数,而浮点数的运算速度较慢且可能产生误差等精度问题,因此提出了以数论 ...

  4. Algorithm: 多项式乘法 Polynomial Multiplication: 快速傅里叶变换 FFT / 快速数论变换 NTT

    Intro: 本篇博客将会从朴素乘法讲起,经过分治乘法,到达FFT和NTT 旨在能够让读者(也让自己)充分理解其思想 模板题入口:洛谷 P3803 [模板]多项式乘法(FFT) 朴素乘法 约定:两个多 ...

  5. 快速傅里叶变换FFT& 数论变换NTT

    相关知识 时间域上的函数f(t)经过傅里叶变换(Fourier Transform)变成频率域上的F(w),也就是用一些不同频率正弦曲线的加 权叠加得到时间域上的信号. \[ F(\omega)=\m ...

  6. [快速数论变换 NTT]

    先粘一个模板.这是求高精度乘法的 #include <bits/stdc++.h> #define maxn 1010 using namespace std; char s[maxn]; ...

  7. 快速数论变换(NTT)小结

    NTT 在FFT中,我们需要用到复数,复数虽然很神奇,但是它也有自己的局限性--需要用double类型计算,精度太低 那有没有什么东西能够代替复数且解决精度问题呢? 这个东西,叫原根 原根 阶 若\( ...

  8. JZYZOJ 2041 快速数论变换 NTT 多项式

    http://172.20.6.3/Problem_Show.asp?id=2041 https://blog.csdn.net/ggn_2015/article/details/68922404 代 ...

  9. 模板 - 数学 - 多项式 - 快速数论变换/NTT

    Huffman分治的NTT,常数一般.使用的时候把多项式的系数们放进vector里面,然后调用solve就可以得到它们的乘积.注意这里默认最大长度是1e6,可能需要改变. #include<bi ...

随机推荐

  1. 【codeforces 821E】Okabe and El Psy Kongroo

    [题目链接]:http://codeforces.com/problemset/problem/821/E [题意] 一开始位于(0,0)的位置; 然后你每次可以往右上,右,右下3走一步; (x+1, ...

  2. 局部特化 & 特化

    注意,显式特化不是一个模板.如果是类型跟显式特化一样,那么不是实例化. 显式特化类的函数,不需要再加template,因为不是模板方法. 特化类的函数跟模板类不一定要一样,但是一样更好. 不支持局部特 ...

  3. 不要小看了get 与set

    不知道大家曾经是怎么使用实体中的get与set的.我先前是这样使用的. 先定义一个实体类.之后写与之相关的字段名称.最后匹配上与之相关的属性,控制字段的读写权限. 曾经使用方式 代码1 public ...

  4. 18.angularJS服务

    转自:https://www.cnblogs.com/best/tag/Angular/ 服务 AngularJS功能最基本的组件之一是服务(Service).服务为你的应用提供基于任务的功能.服务可 ...

  5. 特性Attibute定义和使用

    1.定义特性 [AttributeUsage(AttributeTargets.Class,AllowMultiple = false,Inherited = false)] public class ...

  6. javascript学习笔记总结

    1 有些浏览器可能不支持JavaScript,我们可以使用如下的方法对它们隐藏JavaScript代码. <html> <body> <script type=" ...

  7. Ubuntu 16.04 实现有线 无线同时用

    因为工作的原因,经常会用有线网卡连接服务器进行配置,无线网卡上外网. 一.查看当前网关信息 pipci@ubuntu:~$ ip route showdefault via 192.168.2.1 d ...

  8. cz.msebera.android.httpclient.conn.ConnectTimeoutException: Connect to /192.168.23.1:8080 timed out(Android访问后台一直说链接超时)

    明明之前还是可以运行的练习,过段时间却运行不了,一直说访问后台超时, 对于这个问题我整整弄了两天加一个晚上,心酸...,上网找了很多但是都解决不了,我就差没有砸电脑了. 首先 : 第一步:Androi ...

  9. MySQL架构组成之逻辑模块组成

    MySQL 能够看成是二层架构   第一层SQL Layer.包含权限推断.sql 解析.运行计划优化,query cache 的处理等等.   第二层存储引擎层(Storage Engine Lay ...

  10. 程序猿的量化交易之路(13)--Cointrader类图(1)

    转载须注明出处:http://blog.csdn.net/minimicall? viewmode=contents, htpp://cloudtrader.top 今天開始正式切入到Cointrad ...