SkyWT

3/14/2018

BZOJ1002 轮状病毒 题解

This blog post is only available in Simplified Chinse.

BZOJ原题链接)这题是可以推出公式的:F[i]=F[i-1]*3-F[i-2]+2。套个高精度就好了。(由于需要用到的知识太复杂,推不来……)(其实可以写个暴力推出来)

代码如下:

#include
#include
#include
#include
using namespace std;
const int maxn=105,maxlen=105,tt=10000;
int n;
struct Bigint{
    int len,a[maxlen];
    Bigint(){len=0;memset(a,0,sizeof(a));}
    Bigint operator =(int b){
        while (b) a[++len]=b%tt,b/=tt;
    }
    Bigint operator +(Bigint b){
        Bigint c;memset(c.a,0,sizeof(c.a));
        c.len=max(len,b.len);
        for (int i=1;i<=c.len;i++){
            c.a[i]+=a[i]+b.a[i];
            c.a[i+1]+=c.a[i]/tt;
            c.a[i]%=tt;
        }
        if (c.a[c.len+1]) c.len++;
        return c;
    }
    Bigint operator -(Bigint b){
        Bigint c;memset(c.a,0,sizeof(c.a));
        c.len=len;
        for (int i=1;i<=c.len;i++){
            c.a[i]+=a[i]-b.a[i]+tt;
            c.a[i+1]+=c.a[i]/tt-1;
            c.a[i]%=tt;
        }
        if (!c.a[c.len]) c.len--;
        return c;
    }
    Bigint operator *(int b){
        Bigint c;memset(c.a,0,sizeof(c.a));
        c.len=len;
        for (int i=1;i<=c.len;i++){
            c.a[i]+=a[i]*b;
            c.a[i+1]+=c.a[i]/tt;
            c.a[i]%=tt;
        }
        while (c.a[c.len+1]) c.len++;
        return c;
    }
    void write(){
        printf("%d",a[len]);
        for (int i=len-1;i>=1;i--) printf("%04d",a[i]);
    }
}f[4];
int main(){
    scanf("%d",&n);
    Bigint two;two=2;
    f[1]=1;f[2]=5;
    for (int i=3;i<=n;i++) f[i%4]=f[(i-1+4)%4]*3-f[(i-2+4)%4]+two;
    f[n%4].write();printf("\n");
    return 0;
}

Post a New Comment

Please login to leave a comment.