(转载)有关反演和gcd
tips :
积性函数 F (n) = Π F (piai )
若F (n), G (n)是积性函数则
F (n) * G (n)
Σd | n F (n)
是积性函数
n = Σd | n φ (d)
1 = Σd | n μ (d)
Σgcd (i, n) = 1 i = n * φ (n) / 2
Problem1
F (n) = Σ1<= i <= n gcd(i, n), n <= 1000000
Sol
枚举结果
F (n) = Σd | n d * Σgcd (i, n) = d 1
F (n) = Σd | n d * Σgcd (i / d, n / d) = 1 1
F (n) = Σd | n d * Σgcd (i / d, n / d) = 1 1
F (n) = Σd | n d * φ (n / d)
单次计算O (sqrt N)
筛法O (N)
Problem 2
F (n) = Σ1<= i <= n gcd (i, n), n <= 2147483647 (POJ longge's problem)
Sol
由P1可知F (n)是积性函数 因此考虑计算F (pk)
由P1 易知
F (pk) = p * F (pk - 1) + (p - 1)pk - 1
单个F(n)可以O (sqrt N)时间有他的质因子分解计算得到
Problem 3
F (n) = Σ1<= i <= n lcm(i, n), n <= 1000000 (SPOJ LCMSUM)
显而易见的变形
F (n) = Σ1<= i <= n i * n / gcd (i, n)
F (n) =Σd | n Σgcd (i, n) = d i * n / d
F (n) =Σd | n n / d * Σgcd (i, n) = d i
F (n) =Σd | n n / d * Σgcd (i / d, n / d) = 1 i
F (n) =Σd | n n / d * d * Σgcd (i / d, n / d) = 1 i / d
令j = i / d
F (n) =Σd | n n * Σgcd (j, n / d) = 1 j
由Σgcd (i, n) = 1 i = n * φ (n) / 2
F (n) =Σd | n n * (n / d) * φ (n / d) / 2
F (n) =n * Σd | n (n / d) * φ (n / d) / 2
F (n) =n / 2 * Σd | n d * φ (d)
筛出 Σd | n d * φ (d) O (N)-O(1)
Problem 4
F (n) = Σ1<= i <= n Σ1<= j <= n gcd (i, j) n <= 1000000 (SPOJ GCDEX)
Sol
G (n) = Σd | n d * φ (n / d)
F (n) = Σ1<= i <= n G (i)
筛出G (i) 前缀和
Problem 5
求F (n, m) = [n / d] * [m / d]
Sol
研究退化情况 m = 1 F (n) = [n / d]
共有sqrt n种不同取值
F (n, m) = [n / d] * [m / d]
共有sqrt n + sqrt m种不同取值 归并这两种取值
Problem 6
多组询问n, m 求F (n, m) = Σ1<= i <= n Σ1<= j <= m gcd (i, j)
Sol
F (n, m) = Σ1<= i <= n Σ1<= j <= m Σ d | gcd (i, j) φ (d)
F (n, m) = Σ d φ (d) Σ1<= i <= n d | i Σ1<= j <= m d | j 1
F (n, m) = Σ d φ (d) * [n / d] * [m / d]
可以经P5解决
Problem 6
多组询问n, m 求F (n, m) = Σ1<= i <= n Σ1<= j <= m gcd (i, j) = 1 1
Sol
F (n, m) = Σ1<= i <= n Σ1<= j <= m Σ d | gcd (i, j) μ (d)
F (n, m) = Σ d μ (d) Σ1<= i <= n d | i Σ1<= j <= m d | j 1
F (n, m) = Σ d μ (d) * [n / d] * [m / d]
可以经P5解决
Problem 7
F (n, m) = Σ1<= i <= n Σ1<= j <= m Σ gcd (i, j) <- prime 1 (BZOJ YY的GCD)
Sol
F (n, m) = Σ1<= i <= n Σ1<= j <= m Σ gcd (i, j) <- prime 1
F (n, m) = Σ1<= i <= n Σ1<= j <= m Σ p <- prime gcd (i, j) = p 1
F (n, m) = Σ p <- prime Σ1<= i <= n Σ1<= j <= m gcd (i, j) = p 1
F (n, m) = Σ p <- prime Σ1<= i <= n / p Σ1<= j <= m / p gcd (n / p, m / p) = 1 1
可以经P6解决
(转载)有关反演和gcd的更多相关文章
- 【莫比乌斯反演】关于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( ...
- 数学:莫比乌斯反演-GCD计数
Luogu3455:莫比乌斯反演进行GCD计数 莫比乌斯反演就是用来解决这一类问题的,通常f函数是要求的那个,F函数是显然的 这样利用F的结果就可以推出来f的结果 在计算结果的时候整除分快儿一下就可以 ...
- ZOJ 3435 Ideal Puzzle Bobble 莫比乌斯反演
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4119 依然是三维空间内求(1,1,1)~(a,b,c)能看到的整点数,平移一下 ...
- [洛谷2257]YY的GCD 题解
整理题目转化为数学语言 题目要我们求: \[\sum_{i=1}^n\sum_{i=1}^m[gcd(i,j)=p]\] 其中 \[p\in\text{质数集合}\] 这样表示显然不是很好,所以我们需 ...
- NOI2010能量采集(数论)
没想到NOI竟然还有这种数学题,看来要好好学数论了…… 网上的题解: 完整的结题报告: 首先我们需要知道一个知识,对于坐标系第一象限任意的整点(即横纵坐标均为整数的点)p(n,m),其与原点o(0,0 ...
- OI题目类型总结整理
## 本蒟蒻的小整理qwq--持续更新(咕咕咕) 数据结构 数据结构 知识点梳理 数据结构--线段树 推荐yyb dalao的总结--戳我 以后维护线段树还是把l,r写到struct里面吧,也别写le ...
- loj2000[SDOI2017]数字表格
题意:f为Fibnacci数列.求$\prod_{1<=i<=n,1<=j<=m} f[gcd(i,j)]$. n,m<=1e6. 标程: #include<bit ...
- 莫比乌斯反演学习笔记(转载自An_Account大佬)
转载自An_Account大佬 提示:别用莫比乌斯反演公式,会炸的 只需要记住: [gcd(i,j)=1]=∑d∣gcd(i,j)μ(d)[gcd(i,j)=1]=\sum_{d|gcd(i,j)}\ ...
- 洛谷P2568 GCD (欧拉函数/莫比乌斯反演)
P2568 GCD 题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入输出样例 输入 ...
随机推荐
- H264相关代码
H.264格式的视频打包成RTP后进行发送,编译环境为VC6++ #include <stdio.h> #include <stdlib.h> #include <str ...
- Linux下crontab详解
1.crond介绍 crond是Linux下的任务调度命令,让系统定期执行指定程序.crond命令每分钟都会检查是否有要执行的工作,若有要执行的程序便会自动执行. linux下任务调度工作主要分两类: ...
- 安装Ubuntu时,遇到自定义交换空间swap大小设置问题
【整理】Ubuntu自定义分区设置 在安装Ubuntu时,如果使用的是一个新硬盘那么安装向导会建议你使用整个硬盘,如果硬盘上已经有数据了,向导会建议使用剩余的空间。不管怎样,是由向导自动划分的分区。 ...
- bootstrap 框架选型过程
1.看有没有帮助文档,帮助文档的完整程度. 2.是否是我们业务需要的,花哨的功能真的有用吗? 对于偏pc端使用的系统 toggles意义不大 bootstrap和extjs的区别是什么呢? easyU ...
- 自己实现的android树控件,android TreeView
1.开发原因 在项目中经常需要一个需要一个树状框架,这是非常常见的控件.不过可能是谷歌考虑到android是手机系统,界面宽度有限, 所以只提供了只有二级的ExpandableListView.虽然这 ...
- MongoDB 学习
MongoDB 的官方网站 :https://www.mongodb.org 可通过官方网站下载相应的文件 下载之后对文件进行解压 http://www.cnblogs.com/huangxinche ...
- 1195: [HNOI2006]最短母串 - BZOJ
Description 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串.Input 第一行是一个正整数n(n<=12), ...
- hibernateTemplate的load方法
hibernateTemplate的load方法采用延迟加载,所以应当注意. 如果配置不当,采用此方法获取对象,往往会出现异常: javax.servlet.ServletException: org ...
- Nginx 禁止访问某个目录或文件的设置方法
如果基于WEB根目录下,要禁止用户访问/config目录,或者要禁止用户访问/config.ini(ZF常用INI,不过建议还是放到WEB目录以外的地方),可以通过location进行配置,返回403 ...
- spoj 95
栈应用 ...... 水题 #include<cstdio> #include<cstdlib> #include<cstring> #include<alg ...