【Luogu3808】多项式乘法FFT
来源:互联网 发布:淘宝夜店装 编辑:程序博客网 时间:2024/06/07 06:18
题目戳我
一道模板题
自己尝试证明了大部分。。。
剩下的还是没太证出来。。。
所以就是一个模板放在这里
以后再来补东西吧。。。。
#include<iostream>#include<cstdio>#include<cstdlib>#include<cstring>#include<cmath>#include<complex>#include<algorithm>using namespace std;#define MAX 2700000 inline int read(){ register int x=0,t=1; register char ch=getchar(); while((ch<'0'||ch>'9')&&ch!='-')ch=getchar(); if(ch=='-'){t=-1;ch=getchar();} while(ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();} return x*t;}const double Pi=acos(-1);int N,M,r[MAX],l;complex<double> a[MAX],b[MAX];void FFT(complex<double> *P,int opt){ for(int i=0;i<N;++i)if(i<r[i])swap(P[i],P[r[i]]); for(int i=1;i<N;i<<=1) { complex<double> W(cos(Pi/i),opt*sin(Pi/i)); for(int p=i<<1,j=0;j<N;j+=p) { complex<double> w(1,0); for(int k=0;k<i;k++,w*=W) { complex<double> X=P[j+k],Y=w*P[j+k+i]; P[j+k]=X+Y;P[j+k+i]=X-Y; } } }}int main(){ N=read();M=read(); for(int i=0;i<=N;++i)a[i]=read(); for(int i=0;i<=M;++i)b[i]=read(); M+=N; for(N=1;N<=M;N<<=1)++l; for(int i=0;i<N;++i)r[i]=(r[i>>1]>>1)|((i&1)<<(l-1)); FFT(a,1); FFT(b,1); for(int i=0;i<=N;++i)a[i]=a[i]*b[i]; FFT(a,-1); for(int i=0;i<=M;++i)printf("%d ",(int)(a[i].real()/N+0.5)); return 0;}
阅读全文
0 0
- 【Luogu3808】多项式乘法FFT
- FFT uoj34 多项式乘法
- FFT与多项式乘法
- FFT uoj34 多项式乘法
- [UOJ 34]多项式乘法(FFT)
- FFT多项式乘法学习笔记
- [挖坑][uoj]多项式乘法 FFT
- 【FFT优化】[UOJ#34]多项式乘法
- 【UOJ#34】 多项式乘法(FFT && NTT)
- [FFT 模板题] UOJ #34 多项式乘法
- [UOJ#34]多项式乘法(FFT)
- [uoj 34 多项式乘法] FFT&NTT 模板
- FFT模板(UOJ34多项式乘法)
- uoj 34 多项式乘法(fft入门)
- UOJ 34 多项式乘法(FFT)
- [UOJ#34]多项式乘法(FFT)
- [uoj 34 多项式乘法] FFT&NTT 模板
- uoj34 多项式乘法【FFT or NTT】
- div标签模拟textarea
- HDU 5510 Bazinga 多种姿势
- 看电影
- windows下redis的基本命令
- 高斯消元法求解方程组
- 【Luogu3808】多项式乘法FFT
- CCF CSP 2014年9月第3题 字符串匹配(strstr函数的应用)
- 大话设计模式之访问者模式
- 第十章g2o_custombundle中的common文件夹中的flags文件夹下的command_args.h
- BTRFS文件系统安装ArchLinux
- 在家打游戏
- linux 上网设置
- xgboost
- 数据分析介绍之三——单变量数据观察之核密度估计