zoukankan      html  css  js  c++  java
  • 【Luogu3803】多项式乘法FFT(FFT)

    题目戳我
    一道模板题
    自己尝试证明了大部分。。。
    剩下的还是没太证出来。。。
    所以就是一个模板放在这里
    以后再来补东西吧。。。。

    #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;
    }
    
  • 相关阅读:
    c#异步执行方法
    sql 增加、修改、删除触发器小例子
    c#解决高并发加锁(Lock)
    sql中写事物和c#中执行事物
    socket 服务器浏览器与服务器客户端实例
    c# 写txt
    vs2003 序列化json
    一个完整的Windows 服务从创建到安装卸载
    js封装长度验证
    jquery 右下角弹出框
  • 原文地址:https://www.cnblogs.com/cjyyb/p/7622137.html
Copyright © 2011-2022 走看看