这篇文章参考了许多资料和自己的理解。

先放理论基础。

最大公约数:小学学过,这里只提一些重要的公式:

$·$若$a=b$,则$\gcd(a,b)=a=b$;

$·$若$\gcd(a,b)=d$,则$\gcd(b,a-b)=d$,所以就有了欧几里得辗转相除法;

$·$如果$a$为偶数,$b$为奇数,则$\gcd(a,b)=\gcd\left(\dfrac a2,b\right)$;

$·$如果$a$、$b$均为偶数,则$\gcd(a,b)=2\times \gcd\left(\dfrac a2,\dfrac b2\right)$。

$·$若$\gcd(a,b)=d$,则$\gcd\left(\dfrac ad,\dfrac bd\right)=1$;

数论函数:定义域为正整数、值域是复数的子集的函数称为数论函数。$\text{OI}$中一般都是整数。

积性函数:设$f$为数论函数,对于任意互质的两个正整数$a$、$b$,且$f(a)f(b)=f(ab)$,则$f$是积性函数。如果对于任意两个正整数$a$、$b$满足$f(a)f(b)=f(ab)$,则称之为完全积性函数。区别两者。

因式分解:这个小学就学过了。用现在的知识说,$n=p_1^{\alpha_1}p_2^{\alpha_2}···p_s^{\alpha_s}$是$n$的标准分解,$p_1,p_2,···,p_s$均为质数。

根据以上三条,可以得到:对于积性函数$f$,有$f(n)=f(p_1^{\alpha_1})f(p_2^{\alpha_2})···f(p_s^{\alpha_s})$,所以研究积性函数可以研究其在素数的幂上的取值。

所以我们可以用$\text{Euler}$筛法线性时间内求解出所需的$f$的值。

单位函数$\epsilon(n)=[n=1]=\left\{\begin{aligned}1,n=1\\0,n\ne1\end{aligned}\right.$。其中$[\text{state}]$表示当$\text{state}$为真时值为$1$,否则为$0$。单位函数是完全积性函数

除数函数:$\sigma_k(n)$表示$n$的因子的$k$次方之和:$\sigma_k(n)=\sum\limits_{d|n}d^k$。当$k=0$时变成求其约数个数,此时写作$d(n)$;当$k=1$时变成求约数和,此时写作$\sigma(n)$。除数函数是积性函数

$\text{Euler}$函数:表示不超过$n$且与$n$互质的正整数的个数,根据容斥原理可得:$\varphi(n)=n·\prod\limits_{i=1}^s\left(1-\dfrac{1}{p_i}\right)$。其中$n=p_1^{\alpha_1}p_2^{\alpha_2}···p_s^{\alpha_s}$是$n$的标准分解。

然后对于$\text{Euler}$函数,有一个性质:$n=\sum\limits_{d|n}\varphi(d)$。

证明:考虑根据与$n$的最大公约数分组,设$\gcd(n,i)=d$,则根据前面所讲的性质得到$\gcd\left(\dfrac nd,\dfrac id\right)=1$,所以与$n$的最大公约数为$d$的数有$\varphi\left(\dfrac nd\right)$,又因为所有$\leq n$的数与$n$的最大公约数$d$一定整除$n$,所以可得:$n=\sum\limits_{d|n}\varphi\left(\dfrac nd\right)=\sum\limits_{d|n}\varphi(d)$。(因为$d$和$\dfrac nd$成对出现,所以可以替换)

要到重点啦~

$\text{Dirichlet}$卷积:设$f$、$g$是数论函数,对于数论函数$h$如果满足$h(n)=\sum\limits_{d|n}f(d)g\left(\dfrac nd\right)$,则称$h$为$f$和$g$的$\text{Dirichlet}$卷积,简写成$h=f*g$。对于任意的数论函数$f$,有$f*\epsilon=f$。$\text{Dirichlet}$卷积满足交换律结合律。$h=f*g$为积性函数当且仅当$f,g$为积性函数。

幂函数:表示$n^k$,写作$\text{Id}_k(n)$,当$k=1$时$k$可不写。一般当作记号。

根据这些我们可以将上面的式子改成$\text{Dirichlet}$卷积的形式,例如除数函数的性质可写成$\sigma_k(n)=\text{Id}_k*1$,$\text{Euler}$函数的性质可写成$\text{Id}=\varphi*1$。

到啦~

$\text{Mobius}$函数:定义$\mu(n)=\left\{\begin{array}{ll}1 & n=1\\(-1)^s & n=p_1p_2···p_s\text{且}p_1,p_2,···,p_s\text{互不相等}\ &\\0 & \text{其他(也就是含有因数为质数的平方)}\end{array}\right.$。$\mu$是积性函数

$\text{Mobius}$函数重要的性质:$\sum\limits_{d|n}\mu(d)=\epsilon(n)$。用$\text{Dirichlet}$卷积表示就是$\mu*1=\epsilon$。

证明:$n=1$时成立是显然的。若$n>1$,设素因子有$s$个,如果$d$出现了$2$次相同的素因子,根据定义$\mu(d)=0$,所以只考虑$d$中素因子的指数为$0$或$1$时。即$d$为$s$个素因子中任意选取$0\text{~}s$个素因子的乘积,所以得:$\sum\limits_{d|n}\mu(d)=\sum\limits_{i=0}^s(-1)^i\left(\begin{matrix}s\\i\end{matrix}\right)=(1-1)^s=0$。结果和$\epsilon$定义一样,即证。

$\text{Mobius}$变换:设$f$为数论函数,若函数$g$满足$g(n)=\sum\limits_{d|n}f(d)$,则称$g$为$f$的$\text{Mobius}$变换,$f$为$g$的$\text{Mobius}$逆变换。也可以写作$g=f*1$。

$\text{Mobius}$反演定理:上面的$\text{Mobius}$变换的充要条件为$f(n)=\sum\limits_{d|n}g(d)\mu\left(\dfrac nd\right)$。可以写作$f=g*\mu$。对此的推导很简单,由$f=g*\mu$得$f*1=g*\mu*1$,根据$\mu*1=\epsilon$得$f*1=g*(\mu*1)=g*\epsilon$,又因为$f*\epsilon=f$,所以$g*\epsilon=g=f*1$,就得到了上面的$\text{Mobius}$变换。

到这,该有的定义还有就说完了。

一般的求解就是利用卷积转化原式,再通过调换求和顺序或者通过整除分块的科技降低复杂度。常用的卷积就是上面所述(还算比较套路的8虽然我还是很弱)。

这里放几个经典的例子(正在施工,待更)

[SDOI2012]Longge的问题:跟Mobius反演没有直接关系,但值得一看。

[HAOI2011]Problem b:跟Mobius有关系啦!之中有整除分块的相关内容,很重要。

Mobius反演学习的更多相关文章

  1. Mobius反演与积性函数前缀和演学习笔记 BZOJ 4176 Lucas的数论 SDOI 2015 约数个数和

    下文中所有讨论都在数论函数范围内开展. 数论函数指的是定义域为正整数域, 且值域为复数域的函数. 数论意义下的和式处理技巧 因子 \[ \sum_{d | n} a_d = \sum_{d | n} ...

  2. SPOJ PGCD (mobius反演 + 分块)

    转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents    by---cxlove 题意 :求满足gcd(i , j)是素数(1 &l ...

  3. 关于Mobius反演

    欧拉函数 \(\varphi\) \(\varphi(n)=\)表示不超过 \(n\) 且与 \(n\) 互质的正整数的个数 \[\varphi(n)=n\cdot \prod_{i=1}^{s}(1 ...

  4. mobius反演讲解

    mobius反演的基本形式为,假设知道函数F(x)=Σf(d) d|x,那么我们可以推出f(x)=Σmiu(d)*F(x/d) d|x,另一基本形式为假设知道函数F(x)=Σf(d) x|d,那么我们 ...

  5. [基本操作] Mobius 反演, Dirichlet 卷积和杜教筛

    Dirichlet 卷积是两个定义域在正整数上的函数的如下运算,符号为 $*$ $(f * g)(n) = \sum_{d|n}f(d)g(\frac{n}{d})$ 如果不强调 $n$ 可简写为 $ ...

  6. Mobius 反演与杜教筛

    积性函数 积性函数 指对于所有互质的整数 aaa 和 bbb 有性质 f(ab)=f(a)f(b)f(ab)=f(a)f(b)f(ab)=f(a)f(b) 的数论函数. 特别地,若所有的整数 aaa ...

  7. Note -「Mobius 反演」光速入门

    目录 Preface 数论函数 积性函数 Dirichlet 卷积 Dirichlet 卷积中的特殊函数 Mobius 函数 & Mobius 反演 Mobius 函数 Mobius 反演 基 ...

  8. 【莫比乌斯反演】关于Mobius反演与gcd的一些关系与问题简化(bzoj 2301 Problem b&&bzoj 2820 YY的GCD&&BZOJ 3529 数表)

    首先我们来看一道题  BZOJ 2301 Problem b Description 对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd( ...

  9. (暂时弃坑)(半成品)ACM数论之旅18---反演定理 第二回 Mobius反演(莫比乌斯反演)((づ ̄3 ̄)づ天才第一步,雀。。。。)

    莫比乌斯反演也是反演定理的一种 既然我们已经学了二项式反演定理 那莫比乌斯反演定理与二项式反演定理一样,不求甚解,只求会用 莫比乌斯反演长下面这个样子(=・ω・=) d|n,表示n能够整除d,也就是d ...

随机推荐

  1. [Advanced Python] 16 - Google style guide for programming

    Ref: Python 风格指南 - 内容目录 这里主要记录一下值得注意的地方. Python语言规范 Lint:vsCode自带 导入:完整路径 异常 Ref: [Python] 07 - Stat ...

  2. Selenium+python上传本地文件或者图片

    基于input标签的,有属性type = file: 首先定位到点击上传的元素(input)然后直接使用send_keys()将文件在本地的路径传进去 代码如下(例子来源于本页面上传图片和文件): f ...

  3. Vertx Future 异常处理

    Vertx Future 异常处理 异常发生 ​ 在使用Vertx进行开发的时候,必不可免使用Future异步编程框架.通过Future的 compose ,可以轻松实现不同异步任务的组合. ​ 但是 ...

  4. Jupyter Notebook安装和使用详情(你不懂我......)

    一.Jupyter Notebook是什么? 1.notebook jupyter 简介 Jupyter Notebook是一个开源Web应用程序,允许您创建和共享包含实时代码,方程式,可视化效果和叙 ...

  5. (6)autotools工具的使用

       autotools是专门用来生成Makefile的一系列工具,包括autoscan.aclocal.autoheader.autoconf.automake等.     (1)autotools ...

  6. element-ui入门

    element-ui入门 element-ui是一个ui库,它不依赖于vue.但是却是当前和vue配合做项目开发的一个比较好的ui框架. Layout布局(el-row.el-col) element ...

  7. pip换源

    PIP 下载慢,给你Python3的pip换个源 一键换源 文章来源:企鹅号 - 从零开始学习python 要实现一键换源需要安装一个模块 pip install pqi PQI相关命令 PQI获取当 ...

  8. EJB生成代码后遇到transient错误

    启动服务的时候遇到这样的错误: 解决方案: 1.找到对应的模块的SesBean文件 2.去掉transient 3.重启服务即可

  9. Java 上传解压zip文件,并且解析文件里面的excel和图片

    需求:上传一个zip文件,zip文件里面包含一个excel和很多图片,需要把excel里面的信息解析出来保存到表中,同时图片也转化成base64保存到数据库表中. PS:为了方便不同水平的开发人员阅读 ...

  10. python爬虫——简易天气爬取

    通过爬虫,抓取http://www.weather.com.cn的天气信息 功能——输入城市代码,获取当日天气,简单的beautifulsoup和requests实现.(城市代码可百度查询,不全部展示 ...