高速数论变换(NTT)
今天的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)的更多相关文章
- 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/常用套路【入门】
原文链接https://www.cnblogs.com/zhouzhendong/p/Fast-Fourier-Transform.html 多项式 之 快速傅里叶变换(FFT)/数论变换(NTT)/ ...
- 从傅里叶变换(FFT)到数论变换(NTT)
FFT可以用来计算多项式乘法,但是复数的运算中含有大量的浮点数,精度较低.对于只有整数参与运算的多项式,有时,\(\text{NTT(Number-Theoretic Transform)}\)会是更 ...
- 【算法】快速数论变换(NTT)初探
[简介] 快速傅里叶变换(FFT)运用了单位复根的性质减少了运算,但是每个复数系数的实部和虚部是一个余弦和正弦函数,因此系数都是浮点数,而浮点数的运算速度较慢且可能产生误差等精度问题,因此提出了以数论 ...
- Algorithm: 多项式乘法 Polynomial Multiplication: 快速傅里叶变换 FFT / 快速数论变换 NTT
Intro: 本篇博客将会从朴素乘法讲起,经过分治乘法,到达FFT和NTT 旨在能够让读者(也让自己)充分理解其思想 模板题入口:洛谷 P3803 [模板]多项式乘法(FFT) 朴素乘法 约定:两个多 ...
- 快速傅里叶变换FFT& 数论变换NTT
相关知识 时间域上的函数f(t)经过傅里叶变换(Fourier Transform)变成频率域上的F(w),也就是用一些不同频率正弦曲线的加 权叠加得到时间域上的信号. \[ F(\omega)=\m ...
- [快速数论变换 NTT]
先粘一个模板.这是求高精度乘法的 #include <bits/stdc++.h> #define maxn 1010 using namespace std; char s[maxn]; ...
- 快速数论变换(NTT)小结
NTT 在FFT中,我们需要用到复数,复数虽然很神奇,但是它也有自己的局限性--需要用double类型计算,精度太低 那有没有什么东西能够代替复数且解决精度问题呢? 这个东西,叫原根 原根 阶 若\( ...
- JZYZOJ 2041 快速数论变换 NTT 多项式
http://172.20.6.3/Problem_Show.asp?id=2041 https://blog.csdn.net/ggn_2015/article/details/68922404 代 ...
- 模板 - 数学 - 多项式 - 快速数论变换/NTT
Huffman分治的NTT,常数一般.使用的时候把多项式的系数们放进vector里面,然后调用solve就可以得到它们的乘积.注意这里默认最大长度是1e6,可能需要改变. #include<bi ...
随机推荐
- Unity Shader (四)片段程序示例
1.环境光+漫反射+高光+点光源 Shader "Custom/Example_Frag_1" { properties { _MainColor(,,,) _Specular ...
- win32下实现透明窗体
最開始写透明窗体的代码,在百度了之后,找到了SetLayeredWindowAttributes()这一个函数,可是因为网上案列的缺少,使得非常多人无法非常好的使用这一个方法,我花了几天的时间写了一个 ...
- Word 操作组件介绍 - Spire.Doc
http://www.cnblogs.com/liqingwen/p/5898368.html
- MVP模式入门(结合Rxjava,Retrofit)
本文MVP的sample实现效果: github地址:https://github.com/xurui1995/MvpSample 老规矩,在说对MVP模式的理解之前还是要再谈谈MVC模式,了解了MV ...
- scikit-learn的线性回归
scikit-learn的线性回归预测Google股票 这是机器学习系列的第一篇文章. 本文将使用Python及scikit-learn的线性回归预测Google的股票走势.请千万别期望这个示例能够让 ...
- 分布式架构中shiro
分布式架构中shiro 前言:前段时间在搭建公司游戏框架安全验证的时候,就想到之前web最火的shiro框架,虽然后面实践发现在netty中不太适用,最后自己模仿shiro写了一个缩减版的,但是中间花 ...
- HDU 4358 Boring counting dfs序+莫队算法
题意:N个节点的有根树,每个节点有一个weight.有Q个查询,问在以u为根的子树中,有恰好出现了K次的weight有多少种. 这是第一次写莫队算法,之前也只是偶有耳闻. 看了别人的代码打的,还是贴上 ...
- Web API总结
1.Web API 控制器(Controller) 继承ApiController 2. Api 的 Url Map: api/{controller}/{id} 每个"Action&quo ...
- Codeforces Round #240 (Div. 2) 题解
A: 1分钟题,往后扫一遍 int a[MAXN]; int vis[MAXN]; int main(){ int n,m; cin>>n>>m; MEM(vis,); ; i ...
- 学习——HTML5
HTML5多用于手机页面制作,因为PC版浏览器大多不兼容,可以通过下面网站查看HTML5浏览器兼容情况: http://www.caniuse.com/#index 一.语义化标签 1.<hea ...