HDU 1402 A+B Problem Plus(FFT模板题)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1402

#include
#include
#include
#include
using namespace std;
#define maxn 65536+5
const double pi=acos(-1.0);
struct cp{
    double a,b;
    cp operator +(const cp &o)const {return (cp){a+o.a,b+o.b};}
    cp operator -(const cp &o)const {return (cp){a-o.a,b-o.b};}
    cp operator *(const cp &o)const {return (cp){a*o.a-b*o.b,b*o.a+a*o.b};}
    cp operator *(const double &o)const {return (cp){a*o,b*o};}
    cp operator !() const{return (cp){a,-b};}
}w[maxn];///复数的表示手段
int pos[maxn];
void fft_init(int len){
    int j=0;while((1<>1]>>1|((i&1)<>1;j>=0;j-=2)  w[j]=w[j>>1];
        for(int j=1;j>1;j+=2)  w[j]=w[j-1]*g;
        for(int j=0;j>1);
            for(int l=0;l>1;l++){
                cp o=b[l]*w[l];
                b[l]=a[l]-o;
                a[l]=a[l]+o;
            }
        }
    }
    if(sta==-1)  for(int i=0;i>1)  len<<=1;
    fft_init(len);
    for(int i=n/2;i>1].b:x[i>>1].a)=a[i];
    for(int i=0;i>1].b:y[i>>1].a)=b[i];
    fft(x,len,1),fft(y,len,1);
    for(int i=0;i>1])*0.25;
    }
    fft(z,len,-1);
    for(int i=0;i>1].b+0.5);
        else  c[i]=(int)(z[i>>1].a+0.5);
}
char s1[maxn],s2[maxn];
int a[maxn],b[maxn],c[maxn<<1];
int main(){
    while(~scanf("%s%s",s1,s2)){
        memset(c,0,sizeof(c));
        int n=strlen(s1),m=strlen(s2);
        for(int i=0;i0)len--;
        for(int i=len;i>=0;i--)printf("%c",c[i]+'0');
        printf("\n");
    }
    return 0;
}

 

你可能感兴趣的:(HDU习题集,快速傅里叶变换(FFT))