《算法竞赛进阶指南》0x32_2约数

2024-08-30 12:04

本文主要是介绍《算法竞赛进阶指南》0x32_2约数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义
∀ a , b ∈ N , 若 g c d ( a , b ) = 1 , 则称 a , b 互质 \forall a,b \in \mathbb{N},若gcd(a,b)=1,则称a,b互质 a,bN,gcd(a,b)=1,则称ab互质
对于三个数或更多个数的情况,我们把 g c d ( a , b , c ) = 1 gcd(a,b,c)=1 gcd(a,b,c)=1的情况称为a,b,c互质。把 g c d ( a , b ) = g c d ( a , c ) = g c d ( b , c ) = 1 gcd(a,b)=gcd(a,c)=gcd(b,c)=1 gcd(a,b)=gcd(a,c)=gcd(b,c)=1称为a,b,c两两互质。后者显然是一个更强的条件。
欧拉函数
[1,N]中与N互质的数的个数被称为欧拉函数,记为 ϕ ( N ) \phi(N) ϕ(N)
若在算数基本定理中, N = p 1 c 1 p 2 c 2 . . . p m c m N=p_1^{c_1}p_2^{c_2}...p_m^{c_m} N=p1c1p2c2...pmcm,则:
ϕ ( N ) = N ∗ p 1 − 1 p 1 ∗ p 2 − 1 p 2 ∗ . . . ∗ p m − 1 p m = N ∗ ∏ 质数 p ∣ N ( 1 − 1 p ) \phi(N)=N*\frac{p_1-1}{p1}*\frac{p_2-1}{p2}*...*\frac{p_m-1}{pm}=N*\prod\limits_{质数p|N}(1-\frac{1}{p}) ϕ(N)=Np1p11p2p21...pmpm1=N质数pN(1p1)

证明:
设p是N的质因子,[1,N]中p的倍数有p,2p,3p,…,(N/p)*p,共N/p个。若q也是N的质因子,则[1,N]中q的倍数有N/q个。如果我们把这N/p+N/q个数去掉,那么p*q的倍数被去掉了两次,需要加一次回来。
因此[1,N]中不与N含有任何共同质因子p或q的数的个数为:
N − N p − N q + N p q = N ( 1 − 1 p ) ( 1 − 1 q ) N-\frac{N}{p}-\frac{N}{q}+\frac{N}{pq}=N(1-\frac{1}{p})(1-\frac{1}{q}) NpNqN+pqN=N(1p1)(1q1)
实际上这种思想叫做容斥原理,在N的全部质因子上使用容斥原理,可得到[1,N]中不与N含有任何公共质因子的数的个数,也就是与N互质的数的个数。

根据欧拉函数的计算式,我们只需要分解质因数,便可以顺便求出欧拉函数。

int phi(int n)
{int ans = n;for (int i = 2; i <= sqrt(n); i ++ )if (n % i == 0){ans = ans / i * (i - 1);while (n % i == 0) n /= i;}if (n > 1) ans = ans / n * (n - 1);return ans;
}

性质1-2
1. ∀ n > 1 , [ 1 , n ] 中与 n 互质的数的和为 n ∗ ϕ ( n ) / 2 \forall n > 1,[1,n]中与n互质的数的和为n*\phi(n)/2 n>1,[1,n]中与n互质的数的和为nϕ(n)/2
2. 若 a , b 互质 , 则 ϕ ( a b ) = ϕ ( a ) ∗ ϕ ( b ) 若a,b互质,则\phi(ab)=\phi(a)*\phi(b) a,b互质,ϕ(ab)=ϕ(a)ϕ(b)

证明:
因为 g c d ( n , x ) = g c d ( n , n − x ) gcd(n,x)=gcd(n,n-x) gcd(n,x)=gcd(n,nx),所以与n不互质的数x,n-x成对出现,平均值为n/2,因此与n互质的数平均值也是n/2,可得性质1。
根据欧拉函数的计算式,对a,b分解质因数直接可得性质2。

积性函数
如果a,b互质,有 f ( a b ) = f ( a ) ∗ f ( b ) f(ab)=f(a)*f(b) f(ab)=f(a)f(b),那么称函数f为积性函数。

性质3-6
3.若f是积性函数,且在算术基本定理中 n = ∏ i = 1 m p i c i n=\prod_{i=1}^{m}p_i^{c_i} n=i=1mpici,则 f ( n ) = ∏ i = 1 m f ( p i c i ) f(n)=\prod_{i=1}^{m}f(p_i^{c_i}) f(n)=i=1mf(pici)
4.设p为质数,若 p ∣ n p|n pn p 2 ∣ n p^2|n p2n,则 ϕ ( n ) = ϕ ( n / p ) ∗ p 。 \phi(n)=\phi(n/p)*p。 ϕ(n)=ϕ(n/p)p
5.设p为质数,若 p ∣ n p|n pn p 2 ! ∣ n p^2!|n p2!n,则 ϕ ( n ) = ϕ ( n / p ) ∗ ( p − 1 ) 。 \phi(n)=\phi(n/p)*(p-1)。 ϕ(n)=ϕ(n/p)(p1)
6. ∑ d ∣ n ϕ ( d ) = n \sum_{d|n}\phi(d)=n dnϕ(d)=n

证明:
性质3显然。
p ∣ n p|n pn p 2 ∣ n p^2|n p2n,则n,n|p包含相同的质因子,只是p的指数不同,把两者按照欧拉函数的计算公式写出,二者相除,商为p,所以性质4成立。
p ∣ n p|n pn p 2 ! ∣ n p^2!|n p2!n则p,n|p互质, ϕ ( n ) = ϕ ( n / p ) ∗ ϕ ( p ) \phi(n)=\phi(n/p)*\phi(p) ϕ(n)=ϕ(n/p)ϕ(p),而 ϕ ( p ) = p − 1 \phi(p)=p-1 ϕ(p)=p1,所以性质5成立。

利用线性筛求1到n所有数的欧拉函数

void init(int n)
{phi[1] = 1;for (int i = 2; i <= n; i ++ ){if (!st[i]){prime[cnt ++ ] = i;phi[i] = i - 1;}for (int j = 0; prime[j] * i <= n; j ++ ){st[i * prime[j]] = 1;if(i % prime[j] == 0){phi[i * prime[j]] = phi[i] * prime[j];//性质4break;}phi[i * prime[j]] = phi[i] * (prime[j] - 1);//性质5}}
}

acwing203.可见的点

如果所有的点与原点的连接构成直线 y = a b x y=\frac{a}{b}x y=bax的话,本题要求的就是在1到n范围内互质的(a,b)的对数是多少,按照y=x分成上下两部分,本题的答案即为 2 ∗ ϕ ( n ) + 1 2*\phi(n)+1 2ϕ(n)+1

#include <iostream>
using namespace std;
#define N 1010
bool st[N];
int prime[N];
int phi[N];
int cnt = 0;void init(int n)
{phi[1] = 1;for (int i = 2; i <= n; i ++ ){if (!st[i]){prime[cnt ++ ] = i;phi[i] = i - 1;}for (int j = 0; prime[j] * i <= n; j ++ ){st[i * prime[j]] = 1;if(i % prime[j] == 0){phi[i * prime[j]] = phi[i] * prime[j];break;}phi[i * prime[j]] = phi[i] * (prime[j] - 1);}}
}
int main()
{init(N - 1);int n, m;cin >> m;for (int T = 1; T <= m; T ++ ){int ans = 1;cin >> n;for (int k = 1; k <= n; k ++ ) ans += 2 * phi[k];cout << T << ' ' << n << ' ' << ans << endl;}return 0;
}

这篇关于《算法竞赛进阶指南》0x32_2约数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120768

相关文章

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

JavaScript错误处理避坑指南

《JavaScript错误处理避坑指南》JavaScript错误处理是编程过程中不可避免的部分,它涉及到识别、捕获和响应代码运行时可能出现的问题,本文将详细给大家介绍一下JavaScript错误处理的... 目录一、错误类型:三大“杀手”与应对策略1. 语法错误(SyntaxError)2. 运行时错误(R

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时