题面:
传送门:洛咕
Solution
首先,我们需要一个结论: $\large d(i,j)=\sum_{xi}\sum_{yj}[gcd(x,y)=1]$
证明 理性证明请看这篇博客的例五 本蒟蒻提供一个感性证明的方法:如果$x*y$是$i*j$的因数,我们必须有$xi,yj$,而后面那个$gcd(x,y)$是用来去重的
有了这个柿子之后,我们之后的推导就比较套路了: 为了方便讨论,之后的柿子均默认$m>n$ 为了方便书写,之后的除法默认向下取整 原式: $\large \sum_{i=1}^n\sum_{j=1}^md(i*j)$ 把我们上面的结论代进去 $\large \sum_{i=1}^n\sum_{j=1}^m\sum_{xi}\sum_{yj}[gcd(x,y)=1]$ 根据套路,这里的$xi$与$yj$应该写成枚举的形式: $\large \sum_{i=1}^n\sum_{j=1}^m\sum_{x=1}^{n}[xi]\sum_{y=1}^{m}[yj][gcd(x,y)=1]$ 这里显然可以把$x,y$的和式写到最前面去: $\large \sum_{x=1}^{n}[xi]\sum_{y=1}^{m}[yj]\sum_{i=1}^n\sum_{j=1}^m[gcd(x,y)=1]$ 然后就可以去掉$x,y$后面的那两个判断式啦 $\large \sum_{x=1}^{n}\sum_{y=1}^{m}\sum_{i=1}^{n/x}\sum_{j=1}^{m/y}[gcd(x,y)=1]$ 然后我们再去套路后面那个$gcd$,根据莫比乌斯函数的性质$[x=1]=\sum_{dx}\mu(d)$,我们就把$gcd$带入得 $\large \sum_{x=1}^{n}\sum_{y=1}^{m}\sum_{i=1}^{n/x}\sum_{j=1}^{m/y}\sum_{dgcd(x,y)}\mu(d)$ 然后去枚举$d$ $\large \sum_{x=1}^{n}\sum_{y=1}^{m}\sum_{i=1}^{n/x}\sum_{j=1}^{m/y}\sum_{d=1}^{n}\mu(d)[dgcd(x,y)]$ 套路地把$\mu$的和式丢到最前面,化简一下就有: $\large \sum_{d=1}^{n}\mu(d)\sum_{x=1}^{n/d}\sum_{y=1}^{m/d}\sum_{i=1}^{n/(x*d)}\sum_{j=1}^{m/(y*d)}1$ 然后有 $\large \sum_{d=1}^{n}\mu(d)\sum_{x=1}^{n/d}\sum_{y=1}^{m/d}\frac{n}{x*d}\frac{m}{y*d}$ 移项整理一下: $\large \sum_{d=1}^{n}\mu(d)\sum_{x=1}^{n/d}\frac{n}{x*d}\sum_{y=1}^{m/d}\frac{m}{y*d}$ 好了,到这里我就不会推了 之后的内容感谢@Maxwei_wzj的教学 事实上,这个柿子我们已经可以算了。 $\large \sum_{d=1}^{n}\mu(d)\sum_{x=1}^{n/d}\frac{n}{x*d}\sum_{y=1}^{m/d}\frac{m}{y*d}$ 首先,我们有一个结论(我不会证) $\large x/(y*z)=(x/y)/z$ (这里的除法向下取整) 我们的柿子就可以变为 $\large \sum_{d=1}^{n}\mu(d)\sum_{x=1}^{n/d}\frac{\frac{n}{d}}{x}\sum_{y=1}^{m/d}\frac{\frac{m}{d}}{y}$ 然后我们再设一个方程: $f(x)=\sum_{i=1}^x\frac{x}{i}$ 我们柿子就可以写为: $\large \sum_{d=1}^{n}\mu(d)f(\frac{n}{d})f(\frac{m}{d})$ 诶?我们好像又能整除分块了。 没错,我们只需要先用$O(n*\sqrt n)$的整除分块预处理出$f$ 然后再每次$O(\sqrt n)$整除分块算出那个柿子就好。 时间复杂度$O(n*\sqrt n)$ 完结撒花✿✿ヽ(°▽°)ノ✿
Code
1 | //Luogu P3327 [SDOI2015]约数个数和 |