前言

咕咕了好久终于来学习莫反了

要不是不让在机房谁会发现数学一本通上有这么神奇的东西

就是没有性质的证明

然后花了两节数学课证明了一遍

舒服~

前置知识:欧拉函数,二项式定理(组合数)

会欧拉函数的可以直接看\(Mobius\)了

欧拉函数

含义

\(\phi (n)\) 表示比\(n\)小的数中与\(n\)互质的数的个数

引理1

  • \(n\)为质数,\(\phi(n) = n - 1\)
  • \(n=a*b\) 且 \((a, b) = 1\),则\(\phi(n) = \phi(a) * \phi(b)\)
  • 对于一个质数\(n\)的\(a\)次方 \(\phi(n^a) = (n - 1) * p^{n-1}\)

    现对于第三条性质给出证明
  • 比\(n^a\)小的数有\(n^a - 1\)个
  • 其中能整除的表示为\(n* t (t = 1, 2, ... n ^{a-1}-1)\)
  • 总计有\(n^{a-1}-1\)个数能被整除
  • 则与其互质的数的个数为\(\phi(p^a) = (n^a-1) - (p^{a-1}+1) = p^a - p^{a-1} = (p-1) * p^{a-1}\)

引理2

对于质数\(n\),唯一分解定理 \(n = {p_1}^{c_1} * {p_2} ^{c_2}...{p_k}^{c_k}\)

$ \phi(n) = n * (1- \frac 1 {p_1}) * (1- \frac 1 {p_2}) ... (1- \frac 1 {p_k})\(**
**若\)a\(与\)m\(互质,\)a^{\phi(m)} \equiv 1 (mod ; m)$

线性筛

根据上述性质,推出

  • 若\(p\)为质数,\(\phi (p) = p - 1\)
  • \(if(i \% p == 0) \:\ \phi(i*p)=p*\phi(i)\)
  • \(if(i \% p \; != 0) \:\ \phi(i*p)=\phi(i)*(p -1)\)

code

  1. inline void pre(int n){
  2. phi[1] = 1;
  3. for(int i = 2; i <= n; i++){
  4. if(!vis[i]){
  5. prime[++cnt] = i;
  6. phi[i] = i - 1;
  7. }
  8. for(int j = 1; j <= cnt && i * prime[j] <= n; j++){
  9. vis[i * prime[j]] = 1;
  10. if(i % prime[j] == 0){
  11. phi[i * prime[j]] = phi[i] * prime[j];
  12. break;
  13. }
  14. else phi[i * prime[j]] = phi[i] * (prime[j] - 1);
  15. }
  16. }
  17. }

莫比乌斯反演(Mobius)

定义

对于非负整数集合上的两个函数\(F(n)\)和\(f(n)\),若满足条件\(F(n)=\sum_{d|n}f(d)\)则

$$f(n)=\sum_{d|n}\mu(d)F(\frac n d)$$

\(\mu\)函数

定义如下

  • 若\(d=1\)则\(\mu(d)=1\)
  • 若\(d=p_1p_2p_3...p_k\)均为互异质数,则\(\mu(d)=(-1)^k\)
  • 其他情况\(\mu(d)=0\)

性质一

\[ \sum_{d|n}\mu(d) =
\begin{cases}
1, & \text n=1 \\
0, & \text n>1
\end{cases}
\]

证明:

若\(n\)为质数,显然\(sum=0\)

若\(n\)为合数,根据唯一分解定理

\[n = {p_1}^{c_1} * {p_2} ^{c_2}...{p_k}^{c_k}
\]

\(n\)的因子\(d\)只能是\(p_1p_2,p_1p_3,p_3p_k\)诸如此类

可以发现\(d\)的构造来自于\(k\)个质因子中选取了\(i\)个

  • \(k\)为奇数即\(n\)中包含奇数个质因子

    从\(k\)中选出奇数个因子,\(\mu\)值为-1,对答案贡献为\(-\sum_{i=1}^kC_k^i(i+=2)\)

    从\(k\)中选出偶数个因子,\(\mu\)值为1,对答案共享为\(\sum_{i=2}^{k-1}C_k^i(i+=2)\)

    两种情况加和化简得\(-C_k^k=-1\)

    \(sum = -1 + \mu(1)=-1+1=0\)

    得证
  • k为偶数即\(n\)中包含偶数个质因子

    同理可得\(sum=0\)

性质二

\[ \sum_{d|n} \frac {\mu(d)} {d} = \frac {\phi(n)} {n}
\]

证明:

同上将\(n\)质因数分解,同时将等号右侧

\[\frac {\phi(n)} n = (1- \frac 1 {p_1}) * (1- \frac 1 {p_2}) ... (1- \frac 1 {p_k})
\]
\[= \frac {(p_1-1)(p_2-1)...(p_k-1)} {p_1p_2...p_k}
\]

同样的,对\(k\)的奇偶性分类讨论

  • \(k\)为奇数

    • 从分子中选取奇数个质因子组成类似于\(p_1p_2p_3\)

      由于剩下了奇数-奇数=偶数个括号,那么在多项式展开式中该项的常数项(不包含其他质因子)系数一定为\(1\)

      与分母约分得到\(\frac {1}{\text {偶数个质因子的积}}\)

      根据\(\mu\)函数的性质可以知道,该化简式等于\(\frac {\mu(\text 分母)} {\text 分母}\)
    • 同理,从中选取偶数个质因子得到的化简结果为

      \(\frac {1}{\text {奇数个质因子的积}}\)

      该化简式也等于\(\frac {\mu(\text 分母)} {\text 分母}\)
    • 当然,分子展开式当中必包含一项\(p_1p_2...p_k=\text 分母\)

      约分结果显然为\(1=\mu(1)/1\)

综上所述$$\frac {\phi(n)}{n}= (1- \frac 1 {p_1}) * (1- \frac 1 {p_2}) ... (1- \frac 1 {p_k})$$

\[=\frac {(p_1-1)(p_2-1)...(p_k-1)} {p_1p_2...p_k}
\]
\[=1+\frac {\mu(d)} {d}(d\neq 1,d|n)
\]
\[=\frac {\mu(1)}{1} +\frac {\mu(d)} {d}(d\neq 1,d|n)
\]
\[= \sum_{d|n} \frac {\mu(d)}{d}
\]

原命题得证

  • \(k\)为偶数

    同理即可证明
\[\frac {\phi(n)}{n}= (1- \frac 1 {p_1}) * (1- \frac 1 {p_2}) ... (1- \frac 1 {p_k})= \sum_{d|n} \frac {\mu(d)}{d}
\]

原命题得证

反演证明

目标性质$$f(n)=\sum_{d|n}\mu(d)F(\frac n d)$$

证明:

由\(F(n)\)与\(f(n)\)的关系\(F(n)=\sum_{d|n}f(d)\)将等式推导:

\[\sum_{d|n}\mu(d)F(\frac n d)=\sum_{d|n}\mu(d)\sum_{d'|\frac n d}f(d')
\]
\[=\sum_{d|n}\sum_{d'|\frac n d}\mu(d)f(d')
\]

可见只有满足\((d*d')|n\)时,函数对答案有贡献

那么不妨交换\(d\)和\(d'\)的位置(理解成范围也行)

\[=\sum_{d'|n}\sum_{d|\frac n {d'}}\mu(d)f(d')
\]
\[=\sum_{d|\frac n {d'}}\mu(d)\sum_{d'|n}f(d')
\]

再观察式子,根据\(\mu(d)\)非\(1\)即\(0\)的性质,来考虑\(d'\)为何值时对答案有贡献

可见当且仅当\(d'=n\)且\(d=\frac {n}{d'}=1\)时,\(\mu(d)=1\)该式不为\(0\)

否则式子值为\(0\)对答案无贡献

\[=1*\sum_{n|n}f(n)
\]
\[=f(n)
\]

综上所述

\[\sum_{d|n}\mu(d)F(\frac n d)=f(n)
\]

原命题得证!

小结

关于\(Mobius\)的性质纸上推导了两天,建议多手模

思维量不小~

欧拉函数线性求解以及莫比乌斯反演(Mobius)的更多相关文章

  1. HDU 1695 GCD 欧拉函数+容斥定理 || 莫比乌斯反演

    GCD Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  2. 【bzoj2401】陶陶的难题I “高精度”+欧拉函数+线性筛

    题目描述 求 输入 第一行包含一个正整数T,表示有T组测试数据.接下来T<=10^5行,每行给出一个正整数N,N<=10^6. 输出 包含T行,依次给出对应的答案. 样例输入 7 1 10 ...

  3. Bzoj 2818: Gcd 莫比乌斯,分块,欧拉函数,线性筛

    2818: Gcd Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 3241  Solved: 1437[Submit][Status][Discuss ...

  4. 欧拉函数(小于或等于n的数中与n互质的数的数目)&& 欧拉函数线性筛法

    [欧拉函数] 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命名,它又称为Euler’s totient function.φ函数.欧拉商数等. 例如φ( ...

  5. hdu 6390 欧拉函数+容斥(莫比乌斯函数) GuGuFishtion

    http://acm.hdu.edu.cn/showproblem.php?pid=6390 题意:求一个式子 题解:看题解,写代码 第一行就看不出来,后面的sigma公式也不会化简.mobius也不 ...

  6. 【bzoj2190】【仪仗队】欧拉函数+线性筛(浅尝ACM-J)

    向大(hei)佬(e)势力学(di)习(tou) Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪 ...

  7. 欧拉筛 线性筛 素数+莫比乌斯的mu[]

    https://blog.csdn.net/qq_39763472/article/details/82428602 模板来自https://blog.csdn.net/Avalon_cc/artic ...

  8. BZOJ4804 欧拉心算(莫比乌斯反演+欧拉函数+线性筛)

    一通套路后得Σφ(d)μ(D/d)⌊n/D⌋2.显然整除分块,问题在于怎么快速计算φ和μ的狄利克雷卷积.积性函数的卷积还是积性函数,那么线性筛即可.因为μ(pc)=0 (c>=2),所以f(pc ...

  9. 【BZOJ2401】陶陶的难题I 欧拉函数+线性筛

    [BZOJ2401]陶陶的难题I 题意:求,n<=1000000,T<=100000 题解:直接做是n*sqrt(n)的,显然会TLE,不过这题a和b都是循环到n,那么就可以进行如下的神奇 ...

随机推荐

  1. python3.6和pip3:Ubuntu下安装升级与踩坑之路

    本文以Ubuntu16.x系统为例,演示如何安装python3.6和相应环境.安装Python3的机器必须要能访问外网才能进行如下操作! 1. 安装方式 在Ubuntu下安装python有两种方式: ...

  2. Elementor如何隐藏页面上的标题(2种办法)

    原文首发于:https://loyseo.com/how-to-hide-page-title-in-elementor/ 本文介绍两种隐藏Elementor页面默认标题的方法,一种是单个隐藏,一种是 ...

  3. 详解 `HTTP` 系列之一

    前言 本文介绍的是HTTP的基础知识,包括HTTP的由来.HTTP的报文信息.状态码.HTTP三个版本的对比等.希望这篇简短的文章能对大家认识HTTP协议提供帮助. HTTP的前世今生 HTTP 由来 ...

  4. npm自定义上传

    npm login # 输入用户名 密码 邮箱 # 要到我们包的根目录里面 npm publish 上传到npm官网命令

  5. 记得设置docker日志文件大小!!!!!

    # vim /etc/docker/daemon.json { "log-driver":"json-file", "log-opts": ...

  6. Spine学习三 - 同时播放两个动画

    这个效果和 Unity的动画分层有点儿像,比如 一个人有一个跑的动画,还有一个站在原地挥手的动画,Unity可以通过动画分层,让人物只需要使用这两个动画实现边跑边挥手的动画效果. 首先介绍一下Spin ...

  7. leetcode刷题-50Pow(x, n)

    题目 实现 pow(x, n) ,即计算 x 的 n 次幂函数. 思路 最初的想法n>0计算res = res*x 计算n次,n<0,将x取倒数后同理,但结果表明计算速度太慢了. 后续应该 ...

  8. 关于跨域策略文件crossdomain.xml文件

    下载flexpaper源码修改后做成swf阅读器,要加入待阅读的swf文件,可以在flex里调用js的方法来获取swf文件的路径的方法,在js只专注获取路径就行,等着flex来调用:但这里会遇到一个问 ...

  9. Django总结(Django十一)

    总结一下自己在完成毕设时写的Django博客: Django的初步启动 pycharm+Django启动我的第一个页面 Django+bootstrap启动登录模板页面 Django中 < a ...

  10. MySQL<=>是什么鬼

    官网描述 NULL-safe equal. This operator performs an equality comparison like the = operator, but returns ...