《算法竞赛进阶指南》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

相关文章

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

在 Windows 上安装 DeepSeek 的完整指南(最新推荐)

《在Windows上安装DeepSeek的完整指南(最新推荐)》在Windows上安装DeepSeek的完整指南,包括下载和安装Ollama、下载DeepSeekRXNUMX模型、运行Deep... 目录在www.chinasem.cn Windows 上安装 DeepSeek 的完整指南步骤 1:下载并安装

nginx-rtmp-module构建流媒体直播服务器实战指南

《nginx-rtmp-module构建流媒体直播服务器实战指南》本文主要介绍了nginx-rtmp-module构建流媒体直播服务器实战指南,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. RTMP协议介绍与应用RTMP协议的原理RTMP协议的应用RTMP与现代流媒体技术的关系2

Spring Boot统一异常拦截实践指南(最新推荐)

《SpringBoot统一异常拦截实践指南(最新推荐)》本文介绍了SpringBoot中统一异常处理的重要性及实现方案,包括使用`@ControllerAdvice`和`@ExceptionHand... 目录Spring Boot统一异常拦截实践指南一、为什么需要统一异常处理二、核心实现方案1. 基础组件

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交