莫比乌斯函数与莫比乌斯反演

【目录】

  • 莫比乌斯函数
  • 莫比乌斯反演

莫比乌斯函数

定义

莫比乌斯函数\(\mu(n)\),当\(n=1\)时,\(\mu(n)=1\);当\(n>1\)时,设\(n\)的唯一分解式为\(n=p_1^{c_1}\cdots p_k^{c_k}\),则\(\mu(n)\)定义为

\[\mu(n)= \begin{cases} (-1)^k,c_1=c_2=\cdots=c_k=1 \\ 0, \exists\, c_i>1(1\leq i\leq k)\\ \end{cases}\]

性质

  • \(\sum\limits_{d|n}\mu(d)=[n=1]\)
    注:约定方括号[]中为一个命题,其结果为\(1\)(该命题为真),或为\(0\)(该命题为假)。例如\([p为质数]\)=\(\begin{cases} 1,p是质数 \\ 0,p不是质数 \\ \end{cases}\)
    证明:\(n=1\)时,显然成立;现设\(n>1\)\(n\)的唯一分解式为\(n=p_1^{c_1}\cdots p_k^{c_k}\),则

\[\begin{aligned} \sum\limits_{d|n}\mu(d) =&\mu(1)+\mu(p_1)+\cdots+\mu(p_k)+\mu(p_1p_2)\\ &+\cdots +\mu(p_{k-1}p_k)+\cdots+\mu(p_1\cdots p_k)\\ =&1+\binom{k}{1}(-1)+\binom{k}{2}(-1)^2+\cdots+\binom{k}{k}(-1)^k\\ =&(1-1)^k=0 \end{aligned}\]

  • \(\varphi(n)=\sum\limits_{d|n}\mu(d)\dfrac{n}{d}\)
    证明:
    因为\(\varphi(n)=n\left(1-\dfrac{1}{p_1}\right)\cdots\left(1-\dfrac{1}{p_k}\right)\),其中\(n=p_1^{c_1}\cdots p_k^{c_k}\)\(n\)的标准分解式,利用\(\mu(n)\),可得\(\varphi(n)=\sum\limits_{d|n}\mu(d)\dfrac{n}{d}\)

莫比乌斯反演

观察这两个等式

\[\begin{aligned} n&=\sum\limits_{d|n}\varphi(d)=\sum\limits_{d|n}\varphi\left(\dfrac{n}{d}\right)\\ \varphi(n)&=\sum\limits_{d|n}\mu(d)\dfrac{n}{d}=\sum\limits_{d|n}\mu\left(\dfrac{n}{d}\right)d\\ \end{aligned}\]

考虑将其推广至一般情况

莫比乌斯变换

对于数论函数\(f(n),g(n)\),若

\[f(n)=\sum\limits_{d|n}g(d)=\sum\limits_{d|n}g\left(\dfrac{n}{d}\right) \]

则称\(f(n)\)\(g(n)\)莫比乌斯变换,而\(g(n)\)\(f(n)\)莫比乌斯逆变换

反演公式

若有两个数论函数\(f(n),g(n)\)满足

\[f(n)=\sum\limits_{d|n}g(d)\qquad \qquad (1) \]

则有

\[g(n)=\sum\limits_{d|n}\mu(d)f\left(\dfrac{n}{d}\right) \qquad \qquad (2) \]

反过来,若满足\((2)\),则\((1)\)也成立。
证明:\(f(n),g(n)\)满足\((1)\),则

\[\begin{aligned} \sum\limits_{d|n}\mu(d)f\left(\dfrac{n}{d}\right)&=\sum\limits_{d|n}\mu(d)\sum\limits_{d'|\frac{n}{d}}g(d')\\ &=\sum\limits_{dd'|n}\mu(d)g(d')\\ &=\sum\limits_{d'|n}\sum\limits_{d|\frac{n}{d'}}\mu(d)g(d')\\ &=\sum\limits_{d'|n}g(d')\sum\limits_{d|\frac{n}{d'}}\mu(d)\\ &=g(n)\\ \end{aligned}\]

反过来,设\(f(n),g(n)\)满足\((2)\),同法可证

\[\begin{aligned} \sum\limits_{d|n}g(d)&=\sum\limits_{d|n}g\left(\dfrac{n}{d}\right)\\ &=\sum\limits_{d|n}\sum\limits_{d'|\frac{n}{d}}\mu\left(\dfrac{n}{dd'}\right)f(d')\\ &=\sum\limits_{dd'|n}\mu\left(\dfrac{n}{dd'}\right)f(d')\\ &=\sum\limits_{d'|n}f(d')\sum\limits_{d|\frac{n}{d'}}\mu\left(\dfrac{n}{dd'}\right)\\ &=f(n)\\ \end{aligned}\]

在OI中的应用

通常,在OI竞赛中,应用莫比乌斯反演的关键在于构造如下的式子

\[\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}f(\gcd(i,j)) \]

其中\(f(n)\)是一个积性函数。
构造数论函数\(g(n)\)满足\(f(n)=\sum\limits_{d|n}g(d)\)
由莫比乌斯反演公式得\(g(n)=\sum\limits_{d|n}\mu(d)f\left(\dfrac{n}{d}\right)\)
化简原式

\[\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}f(\gcd(i,j))=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}\sum\limits_{d|\gcd(i,j)}g(d) \]

因为\(d|\gcd(i,j)\Leftrightarrow d|i,d|j\),所以\(d\)必须是\(i,j\)的约数
考虑对每个\(d\),枚举\(d\)的倍数,接着化简

\[\begin{aligned} \sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}f(\gcd(i,j))&=\sum\limits_{d=1}^{\min(n,m)}\sum\limits_{d|i}^n \sum\limits_{d|j}^mg(d)\\ &=\sum\limits_{d=1}^{\min(n,m)}\lfloor\frac{n}{d}\rfloor\lfloor\frac{m}{d}\rfloor g(d) \end{aligned}\]

这样只需要枚举\(d\),就能求出\(\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}f(\gcd(i,j))\),时间复杂度为\(O(n)\)
考虑\(\lfloor\frac{n}{d}\rfloor\lfloor\frac{m}{d}\rfloor\)可以使用数论分块,再预处理一下\(g(n)\)的前缀和,时间复杂度降至\(O(\sqrt n)\)
至于\(g(n)\)的计算,因为\(g(n)=\sum\limits_{d|n}\mu(d)f\left(\dfrac{n}{d}\right)\),而\(f(n),\mu(n)\)为积性函数,所以\(g(n)\)也是积性函数。参考这篇博客\(g(n)\)可以在线性时间内求出。

posted @ 2019-02-27 23:32  又又大柚纸  阅读(291)  评论(0编辑  收藏  举报