ccz181078

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: :: 管理 ::

Description

给定n,b,c,d,e以及A0,A1,···,An−1,定义
xk=b×c^4k+d×c^2k+e
f(x)=Sigma(Aix^i),0<=i<=n-1
请你求出f(x0),f(x1),···,f(xn−1)对10^6+3取模的值。

Input

第一行包括五个整数n,b,c,d,e。
接下来一行包括n个整数,代表a0,a1,···,an−1
N<=60000,保证给出的数字都为整数且均在 [0, 10^6]

Output

N行,第i行代表f(xi−1)
多项式多点求值可过,但似乎不是正解
#include<bits/stdc++.h>
typedef std::vector<int> pol;
typedef long long i64;
typedef unsigned long long u64;
const int P=1000003;
int max(int a,int b){return a>b?a:b;}
template<int p>
i64 pw(int a,int n){
    if(n<0)n+=p-1;
    i64 v=1;
    for(;n;n>>=1,a=i64(a)*a%p)if(n&1)v=v*a%p;
    return v;
}
int N,K,r[1<<20|111];
typedef double ld;
struct cplx{
    ld a,b;
    cplx(ld _x=0,ld _y=0):a(_x),b(_y){}
    cplx operator+(cplx w){return cplx(a+w.a,b+w.b);}
    cplx operator-(cplx w){return cplx(a-w.a,b-w.b);}
    cplx operator*(cplx w){return cplx(a*w.a-b*w.b,a*w.b+b*w.a);}
}A[1<<20|111],B[1<<20|111],*Es[2][20],C[1<<20|111],D[1<<20|111];
void pre(int n){
    for(N=2,K=0;N<n;N<<=1,++K);
    for(int i=1;i<N;++i)r[i]=r[i>>1]>>1|(i&1)<<K;
    memset(A,0,sizeof(cplx)*N);
    memset(B,0,sizeof(cplx)*N);
    memset(C,0,sizeof(cplx)*N);
    memset(D,0,sizeof(cplx)*N);
}
const ld pi=acos(-1);
void dft(cplx*a,int t){
    for(int i=1;i<N;++i)if(i<r[i])std::swap(a[i],a[r[i]]);
    for(int i=1,z=0;i<N;i<<=1,++z){
        if(!Es[t==1][z]){
            cplx*E=Es[t==1][z]=new cplx[i];
            for(int j=0;j<i;++j)E[j]=cplx(cos(j*pi/i),t*sin(j*pi/i));
        }
        cplx*E=Es[t==1][z];
        for(int j=0;j<N;j+=i<<1){
            cplx*b=a+j,*c=b+i;
            for(int k=0;k<i;++k){
                cplx x=b[k],y=c[k]*E[k];
                b[k]=x+y;
                c[k]=x-y;
            }
        }
    }
    if(t==-1)for(int i=0;i<N;++i)a[i].a/=N;
}
void mul(cplx*a,cplx*b){
    for(int i=0;i<N;++i)a[i]=a[i]*b[i];
}
void mov(const pol&x,cplx*a){
    for(int i=0;i<x.size();++i)a[i].a=x[i];
}
void mov(cplx*a,const pol&_x){
    pol&x=const_cast<pol&>(_x);
    for(int i=0;i<x.size();++i)x[i]=i64(a[i].a+0.49)%P;
}
void mov(const pol&x,int*a){
    memcpy(a,x.data(),x.size()*sizeof(int));
}
void mov(int*a,const pol&_x){
    pol&x=const_cast<pol&>(_x);
    memcpy(x.data(),a,x.size()*sizeof(int));
}
void chk(pol&w){
    int p=w.size();
    while(p&&!w[p-1])--p;
    w.resize(p);
}
void rev(pol&w){
    std::reverse(w.data(),w.data()+w.size());
}
u64 _c[1007];
pol operator*(const pol&a,const pol&b){
    pol c(a.size()+b.size()-1);
    if(c.size()<=600){
        const int*as=a.data(),ap=a.size(),*bs=b.data(),bp=b.size();
        int*cs=c.data();
        for(int i=0;i<c.size();++i)_c[i]=0;
        for(int i=0;i<ap;++i)for(int j=0;j<bp;++j)_c[i+j]+=u64(as[i])*bs[j];
        for(int i=0;i<c.size();++i)cs[i]=_c[i]%P;
    }else if(c.size()<=5000){
        pre(c.size());
        mov(a,A),mov(b,B);
        dft(A,1),dft(B,1);
        mul(A,B);
        dft(A,-1);
        mov(A,c);
    }else{
        pre(c.size());
        for(int i=0;i<a.size();++i){
            A[i]=a[i]>>10;
            B[i]=a[i]&1023;
        }
        for(int i=0;i<b.size();++i){
            C[i]=b[i]>>10;
            D[i]=b[i]&1023;
        }
        dft(A,1);dft(B,1);dft(C,1);dft(D,1);
        for(int i=0;i<N;++i){
            cplx v1=A[i]*C[i];
            cplx v2=A[i]*D[i]+B[i]*C[i];
            cplx v3=B[i]*D[i];
            A[i]=v1;
            B[i]=v2;
            C[i]=v3;
        }
        dft(A,-1);dft(B,-1);dft(C,-1);
        for(int i=0;i<c.size();++i){
            c[i]=((i64(A[i].a+0.49)<<20)+(i64(B[i].a+0.49)<<10)+i64(C[i].a+0.49))%P;
        }
    }
    chk(c);
    return c;
}
pol operator*(const pol&w,int x){
    pol a(w);
    for(int i=0;i<a.size();++i)a[i]=i64(a[i])*x%P;
    return a;
}
pol operator-(const pol&a,const pol&b){
    pol c(max(a.size(),b.size()));
    mov(a,c.data());
    for(int i=0;i<b.size();++i)c[i]=(c[i]-b[i]+P)%P;
    chk(c);
    return c;
}
pol inv(pol a){
    if(a.size()==1){
        a.resize(1);
        a[0]=pw<P>(a[0],P-2);
        return a;
    }
    pol b=inv(pol(a.data(),a.data()+(a.size()-1)/2+1));
    pol c=b*b*a;
    c=b*2-c;
    c.resize(a.size());
    return c;
}
pol operator/(pol a,pol b){
    chk(a),chk(b);
    rev(a),rev(b);
    int sz=a.size()-b.size()+1;
    b.resize(sz);
    pol c=a*inv(b);
    c.resize(sz);
    rev(c);
    chk(c);
    return c;
}
pol operator%(const pol&a,const pol&b){
    if(a.size()<b.size())return a;
    return a-a/b*b;
}
int cal(const pol&w,i64 x){
    int y=0;
    for(int p=w.size()-1;p>=0;--p)y=(y*x+w[p])%P;
    return y;
}
int n,b,c,d,e,a[67777],as[67777];
struct Q{int x,id;}qs[67777];
bool operator<(Q a,Q b){return a.x<b.x;}
pol tr[133333];
void calc0(int w,int L,int R){
    if(L==R){
        tr[w]=pol(2);
        tr[w][1]=1;
        tr[w][0]=(P-qs[L].x)%P;
        return;
    }
    int M=(L+R)/2;
    calc0(w<<1,L,M);
    calc0(w<<1^1,M+1,R);
    tr[w]=tr[w<<1]*tr[w<<1^1];
}
void calc1(const pol&a,int w,int L,int R){
    if(R-L<=600){
        for(int i=L;i<=R;++i)as[qs[i].id]=cal(a,qs[i].x);
        return;
    }
    int M=(L+R)/2;
    calc1(a%tr[w<<1],w<<1,L,M);
    calc1(a%tr[w<<1^1],w<<1^1,M+1,R);
}
int main(){
    scanf("%d%d%d%d%d",&n,&b,&c,&d,&e);
    for(int i=0;i<n;++i)scanf("%d",a+i);
    for(int i=0;i<n;++i){
        qs[i].x=(b*pw<P>(c,4*i)+d*pw<P>(c,2*i)+e)%P;
        qs[i].id=i;
    }
    std::sort(qs,qs+n);
    tr[0]=pol(n);
    mov(a,tr[0]);
    calc0(1,0,n-1);
    calc1(tr[0],1,0,n-1);
    for(int i=0;i<n;++i)printf("%d\n",(as[i]+P)%P);
    return 0;
}

 

posted on 2017-07-05 18:08  nul  阅读(338)  评论(0编辑  收藏  举报