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);}

全部评论

相关推荐

点赞 评论 收藏
分享
01-15 17:34
保定学院 Java
数学转码崽:学历没优势就得卷项目和实习啊,但是我看了一下你这个项目,什么雪花算法,搜索引擎,Docker,minio这些都属于通用的东西啊,根本不算亮点,没有任何业务相关性。 还有第二个看到统一鉴权,分片上传估计面试官都不想看了。连我一个偶尔刷刷牛客简历的都看多了,面试官估计早都看吐了。。。 秋招结束了,就尽量找找中小厂吧,毕竟你现在转行已经没时间了,高低有一段实习经历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务