多项式模板整理

多项式乘法

FFT模板

时间复杂度\(O(n\log n)\)。

模板:

void FFT(Z *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1;
        Z wn(cos(pi/i),sin(pi*K/i));
        for(int j=0;j<n;j+=tmp){
            Z w(1,0);
            for(int k=0;k<i;k++,w=w*wn){
                Z x=a[j+k],y=w*a[i+j+k];
                a[j+k]=x+y;a[i+j+k]=x-y;
            }
        }
    }
    if(K==-1)for(int i=0;i<n;i++)a[i]/=n;
}


例题:

【Loj108】多项式乘法

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include<complex>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}

typedef complex<double> Z;
const double pi=M_PI;

int rev[N];
void FFT(Z *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1;
        Z wn(cos(pi/i),sin(pi*K/i));
        for(int j=0;j<n;j+=tmp){
            Z w(1,0);
            for(int k=0;k<i;k++,w=w*wn){
                Z x=a[j+k],y=w*a[i+j+k];
                a[j+k]=x+y;a[i+j+k]=x-y;
            }
        }
    }
    if(K==-1)for(int i=0;i<n;i++)a[i]/=n;
}
Z a[N],b[N];
int main(){
    int n=Getint(),m=Getint();
    for(int i=0;i<=n;i++)a[i].real()=Getint();
    for(int i=0;i<=m;i++)b[i].real()=Getint();

    int x=ceil(log2(n+m+1));
    for(int i=0;i<(1<<x);i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);

    FFT(a,x,1),FFT(b,x,1);
    for(int i=0;i<(1<<x);i++)a[i]*=b[i];
    FFT(a,x,-1);
    for(int i=0;i<=n+m;i++)cout<<(int)(a[i].real()+0.5)<<' ';
    return 0;
}

NTT模板

时间复杂度\(O(n\log n)\)。

模板:

void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}


例题:

【Loj108】多项式乘法

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include<complex>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005,mod=998244353;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}
int ksm(int x,int k){
    int ret=1;
    while(k){
        if(k&1)ret=1ll*ret*x%mod;
        x=1ll*x*x%mod,k>>=1;
    }
    return ret;
}
void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}
int a[N],b[N];
int main(){
    int n=Getint(),m=Getint();
    for(int i=0;i<=n;i++)a[i]=Getint();
    for(int i=0;i<=m;i++)b[i]=Getint();

    int x=ceil(log2(n+m+1));
    NTT(a,x,1),NTT(b,x,1);
    for(int i=0;i<(1<<x);i++)a[i]=(LL)a[i]*b[i]%mod;
    NTT(a,x,-1);
    for(int i=0;i<=n+m;i++)cout<<a[i]<<' ';
    return 0;
}

常用的模数及其原根

r * 2 ^ k + 1 r k g
3 1 1 2
5 1 2 2
17 1 4 3
97 3 5 5
193 3 6 5
257 1 8 3
7681 15 9 17
12289 3 12 11
40961 5 13 3
65537 1 16 3
786433 3 18 10
5767169 11 19 3
7340033 7 20 3
23068673 11 21 3
104857601 25 22 3
167772161 5 25 3
469762049 7 26 3
998244353 119 23 3
1004535809 479 21 3
2013265921 15 27 31
2281701377 17 27 3
3221225473 3 30 5
75161927681 35 31 3
77309411329 9 33 7
206158430209 3 36 22
2061584302081 15 37 7

多项式求逆

前置知识:多项式乘法。

一个多项式有没有逆元完全取决于他的常数项有没有逆元。

时间复杂度\(O(n\log n)\)。

模板:

void Inv(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=ksm(f[0],mod-2),void();
    Inv(f,g,len>>1),copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<(1<<x);i++)g[i]=(mod+2-(LL)A[i]*g[i]%mod)*g[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}


例题

【LGOJ4238】多项式求逆

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005,mod=998244353;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}
int ksm(int x,int k){
    int ret=1;
    while(k){
        if(k&1)ret=(LL)ret*x%mod;
        x=(LL)x*x%mod;
        k>>=1;
    }
    return ret;
}
void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}
void Inv(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=ksm(f[0],mod-2),void();
    Inv(f,g,len>>1),copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<(1<<x);i++)g[i]=(mod+2-(LL)A[i]*g[i]%mod)*g[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
int f[N],g[N];
int main(){
    int n=Getint(),len=ceil(log2(n));
    for(int i=0;i<n;i++)f[i]=(Getint()%mod+mod)%mod;
    Inv(f,g,1<<len);
    for(int i=0;i<n;i++)cout<<g[i]<<' ';
    return 0;
}

多项式开根

前置知识:多项式求逆。

模板:

const int inv2=(mod+1)/2;
void Sqrt(int *f,int *g,int len){
    static int A[N],B[N];
    if(len==1)return g[0]=sqrt(f[0]),void();
    Sqrt(f,g,len>>1),Inv(g,B,len);
    copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(B+len,B+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(B,x,1),NTT(g,x,1);
    for(int i=0;i<n;i++)g[i]=(g[i]+(LL)A[i]*B[i]%mod)%mod*inv2%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}


应用:

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005,mod=998244353;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}
int ksm(int x,int k){
    int ret=1;
    while(k){
        if(k&1)ret=(LL)ret*x%mod;
        x=(LL)x*x%mod;
        k>>=1;
    }
    return ret;
}
void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}
void Inv(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=ksm(f[0],mod-2),void();
    Inv(f,g,len>>1),copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<(1<<x);i++)g[i]=(mod+2-(LL)A[i]*g[i]%mod)*g[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
const int inv2=(mod+1)/2;
void Sqrt(int *f,int *g,int len){
    static int A[N],B[N];
    if(len==1)return g[0]=sqrt(f[0]),void();
    Sqrt(f,g,len>>1),Inv(g,B,len);
    copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(B+len,B+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(B,x,1),NTT(g,x,1);
    for(int i=0;i<n;i++)g[i]=(g[i]+(LL)A[i]*B[i]%mod)%mod*inv2%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
int f[N],g[N];
int main(){
    int n=Getint();
    for(int i=0;i<n;i++)f[i]=Getint();
    int len=ceil(log2(n));
    Sqrt(f,g,1<<len);
    for(int i=0;i<n;i++)cout<<g[i]<<' ';
    return 0;
}

多项式求导

已知多项式\(A(x)\),求:
\[
\frac {dA(x)}{dx}
\]

思路:多项式的每一项都是个简单的幂函数,那么直接对每一项求导就可以了。

void Der(int *f,int *g,int len){
    for(int i=0;i<len;i++)g[i]=(LL)f[i+1]*(i+1)%mod;
    g[len-1]=0;
}

多项式求积分

已知多项式\(A(x)\),求:
\[
\int A(x)dx
\]

思路:同上,直接对每一项积分,\(\int ax^ndx=\frac a{n+1}x^{n+1}\),默认积分后常数为\(0\)。

void Int(int *f,int *g,int len){
    for(int i=1;i<len;i++)g[i]=(LL)f[i-1]*ksm(i,mod-2)%mod;
    g[0]=0;
}

多项式求对数

前置知识:多项式求逆+多项式求导+多项式积分。

模板:

void Ln(int *f,int *g,int len){
    static int A[N],B[N];
    Der(f,A,len),Inv(f,B,len);
    int x=log2(len<<1),n=(1<<x);
    fill(A+len,A+n,0),fill(B+len,B+n,0);
    NTT(A,x,1),NTT(B,x,1);
    for(int i=0;i<n;i++)A[i]=(LL)A[i]*B[i]%mod;
    NTT(A,x,-1),Int(A,g,len);
}


例题

【LGOJ】多项式对数函数

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005,mod=998244353;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}
int ksm(int x,int k){
    int ret=1;
    while(k){
        if(k&1)ret=(LL)ret*x%mod;
        x=(LL)x*x%mod;
        k>>=1;
    }
    return ret;
}
void Der(int *f,int *g,int len){
    for(int i=0;i<len;i++)g[i]=(LL)f[i+1]*(i+1)%mod;
    g[len-1]=0;
}
void Int(int *f,int *g,int len){
    for(int i=1;i<len;i++)g[i]=(LL)f[i-1]*ksm(i,mod-2)%mod;
    g[0]=0;
}
void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}
void Inv(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=ksm(f[0],mod-2),void();
    Inv(f,g,len>>1),copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<(1<<x);i++)g[i]=(mod+2-(LL)A[i]*g[i]%mod)*g[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
void Ln(int *f,int *g,int len){
    static int A[N],B[N];
    Der(f,A,len),Inv(f,B,len);
    int x=log2(len<<1),n=(1<<x);
    fill(A+len,A+n,0),fill(B+len,B+n,0);
    NTT(A,x,1),NTT(B,x,1);
    for(int i=0;i<n;i++)A[i]=(LL)A[i]*B[i]%mod;
    NTT(A,x,-1),Int(A,g,len);
}
int f[N],g[N];
int main(){
    int n=Getint();
    for(int i=0;i<n;i++)f[i]=Getint();
    int len=ceil(log2(n));
    Ln(f,g,1<<len);
    for(int i=0;i<n;i++)cout<<g[i]<<' ';
    return 0;
}

多项式求自然对数为底的指数函数

前置知识:多项式求对数。

模板:

void Exp(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=1,void();
    int x=log2(len<<1),n=1<<x;
    Exp(f,g,len>>1);
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    Ln(g,A,len);
    A[0]=(f[0]+1-A[0]+mod)%mod;
    for(int i=1;i<len;i++)A[i]=(f[i]-A[i]+mod)%mod;
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<n;i++)g[i]=(LL)g[i]*A[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}


例题:

【LGOJ】多项式指数函数

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef long long LL;
const int N=400005,mod=998244353;
using namespace std;
inline int Getint(){register int x=0,f=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;}
int ksm(int x,int k){
    int ret=1;
    while(k){
        if(k&1)ret=(LL)ret*x%mod;
        x=(LL)x*x%mod;
        k>>=1;
    }
    return ret;
}
void Der(int *f,int *g,int len){
    for(int i=0;i<len;i++)g[i]=(LL)f[i+1]*(i+1)%mod;
    g[len-1]=0;
}
void Int(int *f,int *g,int len){
    for(int i=1;i<len;i++)g[i]=(LL)f[i-1]*ksm(i,mod-2)%mod;
    g[0]=0;
}
void NTT(int *a,int x,int K){
    static int rev[N],lst;
    int n=(1<<x);
    if(n!=lst){
        for(int i=0;i<n;i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1);
        lst=n;
    }
    for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
    for(int i=1;i<n;i<<=1){
        int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
        if(K==-1)wn=ksm(wn,mod-2);
        for(int j=0;j<n;j+=tmp){
            int w=1;
            for(int k=0;k<i;k++,w=(LL)w*wn%mod){
                int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
                a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
            }
        }
    }
    if(K==-1){
        int inv=ksm(n,mod-2);
        for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
    }
}
void Inv(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=ksm(f[0],mod-2),void();
    Inv(f,g,len>>1),copy(f,f+len,A);
    int x=log2(len<<1),n=1<<x;
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<(1<<x);i++)g[i]=(mod+2-(LL)A[i]*g[i]%mod)*g[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
void Ln(int *f,int *g,int len){
    static int A[N],B[N];
    Der(f,A,len),Inv(f,B,len);
    int x=log2(len<<1),n=(1<<x);
    fill(A+len,A+n,0),fill(B+len,B+n,0);
    NTT(A,x,1),NTT(B,x,1);
    for(int i=0;i<n;i++)A[i]=(LL)A[i]*B[i]%mod;
    NTT(A,x,-1),Int(A,g,len);
}
void Exp(int *f,int *g,int len){
    static int A[N];
    if(len==1)return g[0]=1,void();
    int x=log2(len<<1),n=1<<x;
    Exp(f,g,len>>1);
    fill(A+len,A+n,0),fill(g+(len>>1),g+n,0);
    Ln(g,A,len);
    A[0]=(f[0]+1-A[0]+mod)%mod;
    for(int i=1;i<len;i++)A[i]=(f[i]-A[i]+mod)%mod;
    NTT(A,x,1),NTT(g,x,1);
    for(int i=0;i<n;i++)g[i]=(LL)g[i]*A[i]%mod;
    NTT(g,x,-1),fill(g+len,g+n,0);
}
int f[N],g[N];
int main(){
    int n=Getint();
    for(int i=0;i<n;i++)f[i]=Getint();
    int len=ceil(log2(n));
    Exp(f,g,1<<len);
    for(int i=0;i<n;i++)cout<<g[i]<<' ';
    return 0;
}

多项式除法

例题

原文地址:https://www.cnblogs.com/Emiya-wjk/p/10025779.html

时间: 2024-10-10 02:00:13

多项式模板整理的相关文章

手机客户端接口开发文档模板整理

这是个人整理的手机开发文档模板,方便自己以后编写文档. 大体内容如下,详细在个人csdn中下载: 移动端转发短信上传温湿度信息 移动端负责后台接收温湿度传感器通过短信发来的温湿度和经纬度信息,移动端后台接收后上传web服务器,当然传感器也可通过wifi直接上传web服务器.返回小写true或者false. 请求URL: http://192.168.1.101:8080/RFID/addTransTemperature.action?phoneNumber=123&temperature=12.

『嗨威说』常见的C++函数模板整理(一)

开学两天,身上的职责直接变为两个班班长,三个小组组长,哇这事情估计够我忙活了,想躲都躲不掉啊,看来我还是真招人推荐各种管理职务啊,以后要是有人推荐我当经理啊领导啊该多好哈哈哈哈.记得今天奶奶生日,很开心地给奶奶打了一通电话,这怕是我第一次给奶奶电话送生日祝福了哈哈哈,是啊,很想珍惜身边的人,但很多时候却一心想提高自己地能力而忽视了身边人,就这四年,就这四年好好提升自己,毕业出来一定要好好陪陪家里祖辈亲戚们. 今天有点特殊,我整理了一下学到这么久编程以来的一些模板和技巧,虽然还没整理完,就作为(一

【POJ 3241】曼哈顿最小生成树(模板整理)

关于 曼哈顿最小生成树 的证明见:http://www.2cto.com/kf/201505/399861.html 模板: #include<cmath> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int MAXN = 100010; const int INF = 0x3f3f3f3f; struct Point{ int x,y,i

模板整理

欧拉函数模板 //直接求解欧拉函数 int euler(int n){ //返回euler(n) int res=n,a=n; for(int i=2;i*i<=a;i++){ if(a%i==0){ res=res/i*(i-1);//先进行除法是为了防止中间数据的溢出 while(a%i==0) a/=i; } } if(a>1) res=res/a*(a-1); return res; } //筛选法打欧拉函数表 #define Max 1000001 int euler[Max]; v

树状数组—模板整理

树状数组整理 update 更新 1.单点更新,将第p个数增加v 1 void update(int p,int v) //将第P个数增加v 2 { 3 while(p<=n) 4 { 5 sum[p] += v; 6 p += lowbit(p); 7 } 8 } 2.区间更新,将区间[x,y]增加v 1 void inerval_update(int x,int y,int v) //区间修改—[x,y]的区间增加v 2 { 3 update(x,v); 4 update(y+1,-v);

[信息学]省选前模板整理

省选前把板子整理一遍,如果发现有脑抽写错的情况,欢迎各位神犇打脸 :) 数学知识 数论: //组合数 //C(n,m) 在n个数中选m个的方案数 ll C[N][N]; void get_C(int n) { for(int i=1;i<=n;i++) { C[i][i]=C[i][0]=1; for(int j=1;j<i;j++) C[i][j]=(C[i-1][j]+C[i-1][j-1])%mod; } } //欧几里得算法 //(a,b) ll gcd(ll a,ll b) { re

有强迫症,总是希望看到的页面简洁美哒哒,就闲着无聊把模板整理了一下。

用的是ThinkInside皮肤. 在设置里添加了一些页面定制的CSS代码: body{background:#333;} #blogTitle h2,#footer,.forFlow a:hover{color:#fff;} .postTitle a:link, .postTitle a:visited, .postTitle a:active,.c_b_p_desc,.postBody,#EntryTag,.diggword,#topics .postDesc,#mainContent{co

LCA模板整理

HDU2586 纯LCA模板 #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> #define lowbit(x) x&(-x) #define rep(i,l,r) for(int i=l;i<=r;++i) #define per(i,r,l) for(int i=r;i>=l;--i) #define ls o<<1 #defin

PWJ的数论模板整理

一些还没学到,但已经听说的就先copy其他博客的 数论 欧拉降幂 求a1^a2^a3^a4^a5^a6 mod m #include<cstdio> #include<cstring> const int N=1e4+11; typedef long long ll; char s[10]; int n,lens,phi[N]; ll md,a[15]; void init(){ for(int i=1;i<N;i++) phi[i]=i; for(int i=2;i<