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. 华为在HDC2021发布全新HMS Core 6 宣布跨OS能力开放

    [2021年10月22日·东莞]华为开发者大会 2021(Together)于今天正式开幕,华为在主题演讲中正式发布全新的HMS Core 6,向全球开发者开放7大领域的69个Kit和21,738个A ...

  2. 机器学习:EM算法

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

  3. 【BZOJ 1419】Red is good [概率DP]

    我 是 Z Z 概率好玄啊(好吧是我太弱.jpg Description 桌面上有R张红牌和B张黑牌,随机打乱顺序后放在桌面上,开始一张一张地翻牌,翻到红牌得到1美元,黑牌则付出1美元.可以随时停止翻 ...

  4. PCB电路板元器件布局的一般原则*(转)

    PCB电路板元器件布局的一般原则: 设计人员在PCB电路板布局过程中需要遵循的一般原则如下. (1)元器件最好单面放置.如果需要双面放置元器件,在底层(Bottom Layer)放置插针式元器件, ) ...

  5. 单片机stm32零基础入门之--初识STM32 标准库

    CMSIS 标准及库层次关系 因为基于Cortex 系列芯片采用的内核都是相同的,区别主要为核外的片上外设的差异,这些差异却导致软件在同内核,不同外设的芯片上移植困难.为了解决不同的芯片厂商生产的Co ...

  6. Python课程笔记(八)

    一些简单的文件操作,学过linux的话理解感觉不会很难.课程代码 一.OS 目录方法 这个模块提供了一种方便的使用操作系统函数的方法 函数 说明 os.mkdir("path") ...

  7. MVC之三个单选按钮的切换选择

    实现需求: 1.三个多选按钮中:只能同时选择限时抢购和分享金或者拼团特惠和分享金,其中限时抢购和拼团特惠不能同时选择.并且点击后显示,再次点击赢隐藏. 1 @*活动信息*@ 2 <div> ...

  8. 测试平台系列(72) 了解ApScheduler基本用法

    大家好~我是米洛! 我正在从0到1打造一个开源的接口测试平台, 也在编写一套与之对应的完整教程,希望大家多多支持. 欢迎关注我的公众号测试开发坑货,获取最新文章教程! 回顾 上一节我们调研了一下市面上 ...

  9. 【性能测试】常见的性能问题分析思路(二)案例&技巧

    上一篇介绍了性能问题分析的诊断的基本过程,还没看过的可以先看下[性能测试]常见的性能问题分析思路-道与术,精炼总结下来就是,当遇到性能问题的时候,首先分析现场,然后根据现象去查找对应的可能原因,在通过 ...

  10. vscode + vim 全键盘操作高效搭配方案

    基础知识 vscode-vim vscode-vim是一款vim模拟器,它将vim的大部分功能都集成在了vscode中,你可以将它理解为一个嵌套在vscode中的vim. 由于该vim是被模拟的的非真 ...