当前位置:网站首页>莫比乌斯反演学习笔记

莫比乌斯反演学习笔记

2022-08-02 15:18:00 Sirius_qwq

Part 0

前置知识:

  • 整除分块

可阅读这篇日报

板子:

for(int i=1,j;i<=n;i=j+1){
    j=n/(n/i);
    ans+=(j-i+1)*(n/i)
}
  • 数论函数

\[\mu(x)=\begin{cases} 1 &amp; x=1 \\ 0 &amp; \textrm{存在} p^2|x,p \in Prime \\ (-1)^k &amp; k\textrm{为质因数个数}\end{cases} \]

PS: \(\mu\) 表示莫比乌斯函数

初学者评价:什么 kb (

狄利克雷卷积:

\[f(x) * g(x) = \sum_{i \mid x}^{} f(i)g(\frac{x}{i} ) \]

\(f(x) * g(x)\) 表示数论函数 \(f(x)\)\(g(x)\) 的狄利克雷卷积,也可写作 \(f * g\)

积性函数:$f(x \times y)=f(x) \times f(y) \left [\gcd(x,y)=1 \right ] $,很多常见的数论函数都是积性函数,例如 \(\mu\)\(\varphi\)

PS: \(\varphi\) 表示欧拉函数

积性函数与狄利克雷卷积的相关性质:如果 \(f\)\(g\) 都是积性函数,那么 \(f * g\) 也是积性函数。

证明咕咕咕

单位函数:\(\epsilon(x)=[x=1]\)

常数函数:\(1(x)=1\)

除数函数:\(\sigma_k(x)=\sum_{d \mid x}d^k\)

欧拉函数:$\varphi(x)=\sum_{i=1}^{x} \left [ \gcd(i,x)=1 \right ] $

恒等函数:\(\operatorname{id}_k(x)=x^k\)\(\operatorname{id}_1(x)\) 通常记作 \(\operatorname{id}(x)\)

一些定理:

\[\mu * 1=\epsilon \]

\[\varphi * 1=\operatorname{id} \]

Part 1

先扔个结论:

\[[\gcd(i,j)==1]\sum_{d \mid \gcd(i,j)} \mu(d) \]

证明:
\(\mu\) 函数有个性质:

\[\sum_{d \mid n} \mu(d)=[n=1] \]

如果 \(\gcd(i,j)=1\) 的话,那么代表着我们按上个结论中枚举的那个 \(n\)\(1\),也就是式子的值是 \(1\),反之,有一个与 \([\gcd(i,j)=1]\) 相同的值:\(0\)

因为 \(\mu\) 函数是积性函数,所以可以用线性筛求出 \(\mu\) 函数,时间复杂度 \(O(n)\)

inline void init(){
	memset(isprime,1,sizeof(isprime));
	isprime[1]=0;mu[1]=1;
	for(int i=2;i<=N;++i){
		if(isprime[i]){
			prime[++cnt]=i;
			mu[i]=-1;
		}
		for(int j=1;j<=cnt&&i*prime[j]<=N;++j){
			isprime[i*prime[j]]=0;
			if(i%prime[j]) mu[i*prime[j]]-=mu[i];
			else{
				mu[i*prime[j]]=0;
				break;
			}
		}
	}
}

Part 2

注:下文中所有除法结果皆默认向下取整

例题1-P2522 [HAOI2011]Problem b

\[\sum_{i=a}^{b} \sum_{j=c}^{d} [\gcd(i,j)=k] \]

考虑容斥,将式子分解为四个部分,每个部分都为

\[\sum_{i=1}^{n} \sum_{j=1}^{m} [\gcd(i,j)=k] \]

大力推柿子:

\[\sum_{i=1}^{\frac{n}{k}} \sum_{j=1}^{\frac{m}{k}} [\gcd(i,j)=1] \]

运用反演定理:

\[\sum_{i=1}^{\frac{n}{k}} \sum_{j=1}^{\frac{m}{k}} \sum_{d \mid \gcd(i,j)} \mu(d) \]

注意到后面的约数可以提到前面枚举:

\[\sum_{d=1}^{\frac{\min(n,m)}{k}}\mu(d)\sum_{i=1}^{\frac{n}{kd}} \sum_{j=1}^{\frac{m}{kd}} \]

\[\sum_{d=1}^{\frac{\min(n,m)}{k}}\mu(d)\frac{n}{kd}\frac{m}{kd} \]

式子可以使用整除分块求解,复杂度 \(O(n+T\sqrt{n})\)

注意:此题如果使用 #define int long long 将会 T 飞,别问我为什么知道,问就是我这么干了

例题2-P2257 YY的GCD

\[\sum_{i=1}^{n} \sum_{j=1}^{m} [\gcd(i,j)\in prime] \]

套路变换一下:

\[\sum_{k=1}^{\min(n,m)} \sum_{i=1}^{n} \sum_{j=1}^{m} [\gcd(i,j)=k](k \in prime) \]

\[\sum_{k=1}^{\min(n,m)} \sum_{i=1}^{\frac{n}{k}} \sum_{j=1}^{\frac{m}{k}} [\gcd(i,j)=1](k \in prime) \]

上我们可爱有趣的莫比乌斯反演:

\[\sum_{k=1}^{\min(n,m)}\sum_{i=1}^{\frac{n}{k}}\sum_{j=1}^{\frac{m}{k}}\sum_{d \mid gcd(i,j)}\mu(d) \]

\[\sum_{k=1}^{\min(n,m)}\sum_{d=1}^{\frac{\min(n,m)}{k}}\mu(d)\frac{n}{kd}\frac{m}{kd} \]

\(T=kd\)

\[\sum_{k=1}^{\min(n,m)}\sum_{d=1}^{\frac{\min(n,m)}{k}}\mu(d)\frac{n}{T}\frac{m}{T} \]

\(T\) 提到前面并枚举:

\[\sum_{T=1}^{\min(n,m)}\frac{n}{T}\frac{m}{T}\sum_{k \mid T,k \in prime}\mu(\frac{T}{k}) \]

后面这个部分可以预处理,处理出前缀和,单次询问整除分块,复杂度 \(O(n+T\sqrt{n})\)

Part 3

一些常见的 trick:

  • 当题目的式子涉及到 \(\gcd\)\(\operatorname{lcm}\) 时,可优先考虑莫反
  • 当出现枚举约数时,可考虑将其提到前面
  • \(\gcd(x,y)>1\) 时,\(\mu(xy)=0\)

本文参考:

原网站

版权声明
本文为[Sirius_qwq]所创,转载请带上原文链接,感谢
https://www.cnblogs.com/hzx-qwq/p/16543805.html