LOJ 题面传送门

首先将 \(\sigma_k(ij)\) 展开:

\[\sigma_k(ij)=\sum\limits_{x\mid i}\sum\limits_{y\mid j}[x\perp y](\dfrac{iy}{x})^k
\]

具体原理就是我们将一组 \(x\mid i,y\mid j,x\perp y\) 的因子对 \((x,y)\) 对应到一个 \(ij\) 的质因子 \(f(x,y)\) 上。考虑每一个质因子 \(p\),由于 \(x\perp y\) 这个限制的存在,\(x,y\) 中 \(p\) 的次数必须至少有一个为 \(0\),如果 \(x\) 中 \(p\) 次数非零那么我们就令 \(f(x,y)\) 质因子 \(p\) 的次数为 \(i\text{ 中质因子 }p\text{ 的次数}-x\text{ 中质因子 }p\text{ 的次数}\),否则我们令 \(f(x,y)\) 中质因子 \(p\) 的次数为 \(i\text{ 中质因子 }p\text{ 的次数}+y\text{ 中质因子 }p\text{ 的次数}\),不难发现这样一组 \(x\mid i,y\mid j,x\perp y\) 的因子对 \((x,y)\) 与一个 \(ij\) 的质因子形成了双射,并且 \(f(x,y)=(\dfrac{iy}{x})\),因此 \(\sigma_k(ij)=\sum\limits_{x\mid i}\sum\limits_{y\mid j}[x\perp y](\dfrac{iy}{x})^k\)。

接下来考虑计算答案:

\[\begin{aligned}
ans&=\sum\limits_{i=1}^n\sum\limits_{j=1}^n\sigma_k(ij)\\
&=\sum\limits_{i=1}^n\sum\limits_{j=1}^n\sum\limits_{x\mid i}\sum\limits_{y\mid j}[x\perp y](\dfrac{iy}{x})^k\\
&=\sum\limits_{i=1}^n\sum\limits_{j=1}^n\sum\limits_{x\mid i}\sum\limits_{y\mid j}(\dfrac{iy}{x})^k\sum\limits_{d\mid x,d\mid y}\mu(d)\\
&=\sum\limits_{d=1}^n\mu(d)d^k\sum\limits_{i=1}^{\lfloor\frac{n}{d}\rfloor}\sum\limits_{j=1}^{\lfloor\frac{n}{d}\rfloor}\sum\limits_{x\mid i}\sum\limits_{y\mid j}(\dfrac{iy}{x})^d\\
&=\sum\limits_{d=1}^n\mu(d)d^k\sum\limits_{i=1}^{\lfloor\frac{n}{d}\rfloor}\sum\limits_{x\mid i}(\dfrac{i}{x})^k\sum\limits_{j=1}^{\lfloor\frac{n}{d}\rfloor}\sum\limits_{y\mid j}y^k\\
&=\sum\limits_{d=1}^n\mu(d)d^k(\sum\limits_{i=1}^{\lfloor\frac{n}{d}\rfloor}i^k\lfloor\dfrac{n}{id}\rfloor)^2
\end{aligned}
\]

考虑怎么维护这个东西,首先整除分块,那么前面的东西等价于求 \(\mu·\text{id}_k\) 的前缀和。根据提公因式 \((\mu·\text{id}_k)*(I·\text{id}_k)=(\mu*I)·\text{id}_k=\epsilon\)。\(I·\text{id}_k\) 的前缀和对于 \(\le 10^7\) 的部分可预处理,\(>10^7\) 的部分可用拉格朗日插值,这样杜教筛一遍可以求出 \(\mu·\text{id}_k\) 的前缀和。后面的 \(\sum\limits_{i=1}^{\lfloor\frac{n}{d}\rfloor}i^k\lfloor\dfrac{n}{id}\rfloor\) 可以再套一层整除分块,\(\text{id}_k\) 的前缀和照样小数据预处理大数据插值。不难发现我们只会在 \(n\) 的关键点处插值,而 \(n\) 的 \(>10^7\) 的关键点最多 \(1000\) 个,因此我们最多插值 \(1000\) 次,总复杂度 \(n^{3/4}+1000k\),可以通过。

const int MAXV=2e7;
const int MAXK=7777;
const int MOD=1e9+7;
ll n;int k,fac[MAXK+5],ifac[MAXK+5];
int qpow(int x,int e){
int ret=1;
for(;e;e>>=1,x=1ll*x*x%MOD) if(e&1) ret=1ll*ret*x%MOD;
return ret;
}
void init_fac(int n){
for(int i=(fac[0]=ifac[0]=ifac[1]=1)+1;i<=n;i++) ifac[i]=1ll*ifac[MOD%i]*(MOD-MOD/i)%MOD;
for(int i=1;i<=n;i++) fac[i]=1ll*fac[i-1]*i%MOD,ifac[i]=1ll*ifac[i-1]*ifac[i]%MOD;
}
int mu[MAXV+5],pr[MAXV/10+5],prcnt=0,idk[MAXV+5],sum[MAXV+5],smu_pw[MAXV+5];
bool vis[MAXV+5];
void sieve(int n){
idk[1]=mu[1]=1;
for(int i=2;i<=n;i++){
if(!vis[i]) mu[i]=-1,pr[++prcnt]=i,idk[i]=qpow(i,k);
for(int j=1;j<=prcnt&&pr[j]*i<=n;j++){
vis[pr[j]*i]=1;idk[pr[j]*i]=1ll*idk[pr[j]]*idk[i]%MOD;
if(i%pr[j]==0) break;mu[i*pr[j]]=-mu[i];
}
}
for(int i=1;i<=n;i++) sum[i]=(sum[i-1]+idk[i])%MOD;
for(int i=1;i<=n;i++) smu_pw[i]=(0ll+smu_pw[i-1]+mu[i]*idk[i]+MOD)%MOD;
}
int pre[MAXK+5],suf[MAXK+5];
unordered_map<ll,int> _sum,_smu_pw;
int calc_sum(ll n){
if(k==0) return n%MOD;
if(n<=MAXV) return sum[n];n%=MOD;
if(_sum.count(n)) return _sum[n];
pre[0]=suf[k+3]=1;int res=0;
for(int i=1;i<=k+2;i++) pre[i]=1ll*pre[i-1]*(n-i+MOD)%MOD;
for(int i=k+2;i;i--) suf[i]=1ll*suf[i+1]*(n-i+MOD)%MOD;
for(int i=1;i<=k+2;i++){
int mul=1ll*sum[i]*pre[i-1]%MOD*suf[i+1]%MOD*ifac[i-1]%MOD*ifac[k+2-i]%MOD;
if((k+2-i)&1) mul=MOD-mul;res=(res+mul)%MOD;
} return _sum[n]=res;
}
int calc_smu_pw(ll n){
if(n<=MAXV) return smu_pw[n];
if(_smu_pw.count(n)) return _smu_pw[n];
int res=1;
for(ll l=2,r;l<=n;l=r+1){
r=n/(n/l);
res=(res-1ll*(calc_sum(r)-calc_sum(l-1)+MOD)*calc_smu_pw(n/l)%MOD+MOD)%MOD;
} return _smu_pw[n]=res;
}
int main(){
scanf("%lld%d",&n,&k);sieve(MAXV);init_fac(MAXK);
int res=0;
for(ll l=1,r;l<=n;l=r+1){
r=n/(n/l);int sm=0;ll lim=n/l;
for(ll L=1,R;L<=lim;L=R+1){
R=lim/(lim/L);
sm=(sm+1ll*(lim/L)%MOD*(calc_sum(R)-calc_sum(L-1)+MOD))%MOD;
} sm=1ll*sm*sm%MOD;
res=(res+1ll*(calc_smu_pw(r)-calc_smu_pw(l-1)+MOD)*sm)%MOD;
} printf("%d\n",res);
return 0;
}

LOJ #6207 - 米缇(杜教筛+拉格朗日插值)的更多相关文章

  1. EOJ Monthly 2019.11 E. 数学题(莫比乌斯反演+杜教筛+拉格朗日插值)

    传送门 题意: 统计\(k\)元组个数\((a_1,a_2,\cdots,a_n),1\leq a_i\leq n\)使得\(gcd(a_1,a_2,\cdots,a_k,n)=1\). 定义\(f( ...

  2. LOJ 6229 LCM / GCD (杜教筛+Moebius)

    链接: https://loj.ac/problem/6229 题意: \[F(n)=\sum_{i=1}^n\sum_{j=1}^i\frac{\mathrm{lcm}(i,j)}{\mathrm{ ...

  3. 【LOJ#572】Misaka Network 与求和(莫比乌斯反演,杜教筛,min_25筛)

    [LOJ#572]Misaka Network 与求和(莫比乌斯反演,杜教筛,min_25筛) 题面 LOJ \[ans=\sum_{i=1}^n\sum_{j=1}^n f(gcd(i,j))^k\ ...

  4. LOJ# 572. 「LibreOJ Round #11」Misaka Network 与求和(min25筛,杜教筛,莫比乌斯反演)

    题意 求 \[ \sum_{i = 1}^{n} \sum_{i = 1}^{n} f(\gcd(i, j))^k \pmod {2^{32}} \] 其中 \(f(x)\) 为 \(x\) 的次大质 ...

  5. LOJ#6491. zrq 学反演(莫比乌斯反演 杜教筛)

    题意 题目链接 Sol 反演套路题? 不过最后一步还是挺妙的. 套路枚举\(d\),化简可以得到 \[\sum_{T = 1}^m (\frac{M}{T})^n \sum_{d \ | T} d \ ...

  6. loj#6229. 这是一道简单的数学题 (??反演+杜教筛)

    题目链接 题意:给定\(n\le 10^9\),求:\(F(n)=\sum_{i=1}^n\sum_{j=1}^i\frac{\mathrm{lcm}(i,j)}{\mathrm{gcd}(i,j)} ...

  7. LOJ#6229. 这是一道简单的数学题(莫比乌斯反演+杜教筛)

    题目链接 \(Description\) 求\[\sum_{i=1}^n\sum_{j=1}^i\frac{lcm(i,j)}{gcd(i,j)}\] 答案对\(10^9+7\)取模. \(n< ...

  8. [复习]莫比乌斯反演,杜教筛,min_25筛

    [复习]莫比乌斯反演,杜教筛,min_25筛 莫比乌斯反演 做题的时候的常用形式: \[\begin{aligned}g(n)&=\sum_{n|d}f(d)\\f(n)&=\sum_ ...

  9. 【51nod1847】奇怪的数学题(Min_25筛+杜教筛)

    题面 传送门 题解 这题有毒--不知为啥的错误调了半天-- 令\(f(i)={sgcd(i)}\),那么容易看出\(f(i)\)就是\(i\)的次大质因子,用\(i\)除以它的最小质因子即可计算 于是 ...

随机推荐

  1. 初学Python-day8 案例2

    中奖率 1 import random 2 num = 123456 3 i = 1 4 while True: 5 win = random.randrange(100000, 999999) 6 ...

  2. 机器学习:EM算法

    EM算法 各类估计 最大似然估计 Maximum Likelihood Estimation,最大似然估计,即利用已知的样本结果,反推最有可能(最大概率)导致这样结果的参数值的计算过程. 直白来讲,就 ...

  3. [no code][scrum meeting] Alpha 2

    项目 内容 会议时间 2020-04-07 会议主题 功能规格说明书review 会议时长 30min 参会人员 OCR组(肖思炀,赵涛)和产品经理 $( "#cnblogs_post_bo ...

  4. OO第三次博客作业--第三单元总结

    一.JML 语言的理论基础及应用工具链 JML 是一种行为接口规格语言,提供了对方法和类型的规格定义手段.通过 JML 和其支持工具,不仅可以基于规格自动构造测试用例,并整合了 SMT Solver ...

  5. 2021.10.11考试总结[NOIP模拟74]

    T1 自然数 发现\(mex\)是单调不降的,很自然地想到用线段树维护区间端点的贡献. 枚举左端点,用线段树维护每个右端点形成区间的\(mex\)值.每次左端点右移相当于删去一个数. 记\(a_i\) ...

  6. Linux C语言链表详细分析

    链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用.链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节 ...

  7. linux下文件特殊权限设置位S和沾附位T(转载)

    今天在创建文件的时候,发现了文件权限末尾有个T,之前没留意过,后来又用c创建(open)了两个文件来查看,在我没有指定权限(省略open的第三个参数)的时候,有时还会出现S,虽然还没弄懂什么时候会出现 ...

  8. 第01课 OpenGL窗口(3)

    接下来的代码段创建我们的OpenGL窗口.我花了很多时间来做决定是否创建固定的全屏模式这样不需要许多额外的代码,还是创建一个容易定制的友好的窗口但需要更多的代码.当然最后我选择了后者.我经常在EMai ...

  9. 痞子衡嵌入式:借助Serial Plot软件测量i.MXRT系列FlexSPI驱动Flash页编程执行时间

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT系列FlexSPI驱动Flash页编程执行时间. 痞子衡之前写过一篇文章 <串行NOR Flash的页编程模式对于量产 ...

  10. sed tr 批量转换邮箱格式 去除"\n" 行尾添加";"

    1:从phpmyadmin上拿下来的数据是这样的: 2:od -c 发现存在\r\n (windows上编码问题) $ od -c sql.csv 先将\r处理掉 $ sed 's/\r//' sql ...