洛谷 - P3768 - 简单的数学题 - 欧拉函数 - 莫比乌斯反演

https://www.luogu.org/problemnew/show/P3768

\(F(n)=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{n}ijgcd(i,j)\)

首先加入方括号并枚举g,提gcd的g:
\(\sum\limits_{g=1}^{n}g\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{n}ij[gcd(i,j)==g]\)

后面的方括号里的g也可以提出来,注意前面有两个id,所以:
\(\sum\limits_{g=1}^{n}g^3 \sum\limits_{i=1}^{\lfloor\frac{n}{g}\rfloor}\sum\limits_{j=1}^{\lfloor\frac{n}{g}\rfloor}ij[gcd(i,j)==1]\)

\(G(n)=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{n}ij[gcd(i,j)==1]\) ,则 \(F(n)=\sum\limits_{g=1}^{n}g^3 G(\lfloor\frac{n}{g}\rfloor)\)\(F(n)\)可以一次对\(G(\lfloor\frac{n}{g}\rfloor)\)分块求出来。

关注 \(G(n)\) 怎么求。

先把 \(G(n)\) 分成两半,设 \(H_1(n)=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{i}ij[gcd(i,j)==1]\) ,显然 \(G(n)=2*H_1(n)-1\)

又设\(H_2(n)=\sum\limits_{i=1}^{n}in[gcd(i,n)==1]\) ,则 $H_1(n)=\sum\limits_{i=1}^{n}H_2(i) $

\(H_2(n)=n\sum\limits_{i=1}^{n}i[gcd(i,n)==1]\),这个不是在疯狂lcm里面见过吗?和一个数gcd为1的不比他大的数的和。

直接套上去:

\(H_2(n)=nH(n)=\frac{n^2}{2}([n==1]+\varphi(n))\)

所以:
\(H_1(n)=\sum\limits_{i=1}^{n}H_2(i) = \sum\limits_{i=1}^{n} \frac{i^2}{2}([i==1]+\varphi(i))\)

故:
\(G(n)=\sum\limits_{i=1}^{n} i^2 ([i==1]+\varphi(i)) -1= \sum\limits_{i=1}^{n} i^2 \varphi(i)\)

感觉可以用杜教筛来求,先线性筛出1e7以内的 \(G(n)\)


#include<bits/stdc++.h>
using namespace std;
typedef long long ll;

ll n;
int mod;
int inv2;
const int MAXN=1e7;

int pri[MAXN+1];
int &pritop=pri[0];
int B[2*MAXN+1];
int pk[MAXN+1];

void sieve(int n=MAXN) {
    memset(B,-1,sizeof(B));
    B[0]=0;
    pk[1]=1;
    B[1]=1;
    for(int i=2; i<=n; i++) {
        if(!pri[i]) {
            pri[++pritop]=i;
            pk[i]=i;
            ll tmp=1ll*i*i;
            if(tmp>=mod)
                tmp%=mod;
            tmp*=(i-1);
            if(tmp>=mod)
                tmp%=mod;
            B[i]=tmp;
        }
        for(int j=1; j<=pritop; j++) {
            int &p=pri[j];
            int t=i*p;
            if(t>n)
                break;
            pri[t]=1;
            if(i%p) {
                pk[t]=p;
                ll tmp=1ll*B[i]*B[p];
                if(tmp>=mod)
                    tmp%=mod;
                B[t]=tmp;
            } else {
                pk[t]=pk[i]*p;
                if(pk[t]==t) {
                    ll tmp=1ll*t*t;
                    if(tmp>=mod)
                        tmp%=mod;
                    tmp*=(t-i);
                    if(tmp>=mod)
                        tmp%=mod;
                    B[t]=tmp;
                } else {
                    ll tmp=1ll*B[t/pk[t]]*B[pk[t]];
                    if(tmp>=mod)
                        tmp%=mod;
                    B[t]=tmp;
                }
                break;
            }
        }
    }
    for(int i=1; i<=n; i++) {
        ll tmp=(ll)B[i]+B[i-1];
        if(tmp>=mod)
            tmp-=mod;
        B[i]=tmp;
    }
}

inline ll qpow(ll x,ll n) {
    if(x>=mod)
        x%=mod;
    ll res=1;
    while(n) {
        if(n&1) {
            res*=x;
            if(res>=mod)
                res%=mod;
        }
        x*=x;
        if(x>=mod)
            x%=mod;
        n>>=1;
    }
    return res;
}

int inv4;
int inv6;

inline int s2(ll n) {
    if(n>=mod)
        n%=mod;
    ll tmp=n*(n+1);
    if(tmp>=mod)
        tmp%=mod;
    tmp*=(n*2+1);
    if(tmp>=mod)
        tmp%=mod;
    tmp*=inv6;
    if(tmp>=mod)
        tmp%=mod;
    return tmp;
}

inline int s3(ll n) {
    if(n>=mod)
        n%=mod;
    ll tmp=n*(n+1);
    if(tmp>=mod)
        tmp%=mod;
    tmp*=tmp;
    if(tmp>=mod)
        tmp%=mod;
    tmp*=inv4;
    if(tmp>=mod)
        tmp%=mod;
    return tmp;
}

inline int id(ll x){
    if(x<=MAXN)
        return x;
    else
        return n/x+MAXN;
}

inline int S(ll n) {
    int idn=id(n);
    if(B[idn]!=-1)
        return B[idn];
    ll ret=s3(n);
    for(ll l=2,r; l<=n; l=r+1) {
        ll t=n/l;
        r=n/t;
        ll tmp=s2(r)-s2(l-1);
        if(tmp<0)
            tmp+=mod;
        tmp*=S(t);
        if(tmp>=mod)
            tmp%=mod;
        ret-=tmp;
    }
    ret%=mod;
    if(ret<0)
        ret+=mod;
    return B[idn]=ret;
}

inline int F(ll n){
    ll res=0;
    for(ll l=1,r;l<=n;l=r+1){
        ll t=n/l;
        r=n/t;
        ll tmp=s3(r)-s3(l-1);
        if(tmp<0)
            tmp+=mod;
        tmp*=S(t);
        if(tmp>=mod)
            tmp%=mod;
        res+=tmp;
    }
    if(res>=mod)
        res%=mod;
    return res;
}

int main() {
#ifdef Yinku
    freopen("Yinku.in","r",stdin);
#endif // Yinku
    scanf("%d%lld",&mod,&n);
    inv2=qpow(2,mod-2);
    inv4=qpow(4,mod-2);
    inv6=qpow(6,mod-2);
    sieve(min(n,(ll)MAXN));
    printf("%d\n",F(n));
    return 0;
}

转载于:https://www.cnblogs.com/Yinku/p/10998781.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值