HDU-6134 (莫比乌斯反演)


HDU-6134 Battlestation Operational





图片说明


#include<bits/stdc++.h>
using namespace std;
const int N=1e6+6;
const int p=1e9+7;
typedef long long ll;
short int mu[N];
bool vis[N];
int prime[N],tot=0;
ll phi[N],f[N],g[N];
void pre(){
    phi[1]=mu[1]=1;
    for(int i=2;i<N;i++){
        if(!vis[i])prime[++tot]=i,phi[i]=i-1,mu[i]=-1;
        for(int j=1;j<=tot&&i*prime[j]<N;j++){
            vis[i*prime[j]]=1;
            if(i%prime[j]==0){
                mu[i*prime[j]]=0;
                phi[i*prime[j]]=phi[i]*prime[j];
                break;
            }
            mu[i*prime[j]]=-mu[i];
            phi[i*prime[j]]=phi[i]*(prime[j]-1);
        }    
    }
    for(int i=1;i<N;i++){
        phi[i]+=phi[i-1];
        if(phi[i]>=p)phi[i]%=p;
        for(int j=i;j<N;j+=i)f[j]++;
        f[i]+=f[i-1];
        if(f[i]>=p)f[i]%=p;
    }
    for(int i=1;i<N;i++){
        if(mu[i])
        for(int j=i;j<N;j+=i){
            g[j]+=mu[i]*f[j/i];
            if(g[j]>=p)g[j]%=p;
            if(g[j]<0)g[j]=(g[j]%p+p)%p;    
        }
        g[i]+=g[i-1];
        if(g[i]>=p)g[i]%=p;
    }
}
int main(){pre();int n;while(scanf("%d",&n)>0)printf("%lld\n",(g[n]+phi[n]-n)%p);}

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务