求最大公约数-欧几里得算法(辗转相除法)

首先,我们得明确最大公约数是什么。

假设有两个整数 aa 和 bb,它们的公约数 就是能够同时整除 aa 和 bb 的整数。换句话说,就是那些既能整除 aa,又能整除 bb 的数。我们找到所有这样的数,然后从中选出最大的那个,就是它们的最大公约数。

举个例子

比如,我们有两个数:1824

  • 18 的约数有:1, 2, 3, 6, 9, 18

  • 24 的约数有:1, 2, 3, 4, 6, 8, 12, 24

它们的公约数就是:1, 2, 3, 6,最大公约数就是 6。

要找最大公约数,有一种非常高效的方法叫做辗转相除法 ,它也叫做欧几里得算法。它的核心思想是:通过一系列的除法操作,不断缩小问题的规模,最终能够求出最大公约数。

辗转相除法的基本思想:

  1. 假设我们有两个数 aa 和 bb,我们希望找它们的最大公约数(GCD)。

  2. 计算 a÷ba÷b 的余数 rr,即: r=a%br=a%b

  3. 然后把 bb 和余数 rr 作为新的两个数,再重复上面的步骤:求新的余数,直到余数为零。

  4. 当余数为零时,最后一个非零的余数就是 aa 和 bb 的最大公约数。

证明辗转相除法的正确性

辗转相除法为什么能有效求出最大公约数呢?这其实跟数学中的贝祖定理(Bézout's identity)有关系。

贝祖定理说的是:对于任意的两个整数 aa 和 bb,它们的最大公约数 gcd(a,b)gcd(a,b) 可以表示成:gcd(a,b)=a×x+b×ygcd(a,b)=a×x+b×y其中 xx 和 yy 是整数。

通过辗转相除法,不断地把 aa 和 bb 进行除法操作,实际上是在逐步逼近这个最大公约数,最终通过一系列的余数关系得出最大公约数。

在每一步的除法过程中,剩下的余数总是保持与原来两个数的公约数相同,只不过逐渐缩小了范围,所以我们可以通过这种方法最终求出最大公约数。

复制代码
int gcd(int a, int b) {
  if (b == 0) return a;
  else return gcd(b, a % b);
}
相关推荐
代码中介商6 分钟前
图论入门:从基础到遍历算法
数据结构·算法·图论
csdn_aspnet7 分钟前
Python 霍尔分区算法(Hoare‘s Partition Algorithm)
开发语言·python·算法
8Qi87 分钟前
LeetCode 295:数据流的中位数(Median Finder)—— Java 题解 ✅
java·算法·leetcode·优先队列··中位数
Trouvaille ~13 分钟前
【Redis篇】Redis 事务:原子性与脚本执行机制
数据库·redis·后端·算法·junit·lua·原子性
飞天狗11115 分钟前
2024第十五届蓝桥杯c/c++B组国赛题解
c语言·数据结构·c++·算法·蓝桥杯
rsuhbsrjms28 分钟前
可视采耳仪器多少钱一台?可视耳勺哪个牌子好?口碑好的可视耳勺
网络·人工智能·算法
finhaz31 分钟前
神经网络等机器学习模型的看法
算法
z2005093031 分钟前
【linux学习】深入理解 Linux 下的静态库与动态库
开发语言·c++·算法
妄想出头的工业炼药师34 分钟前
腿式里程计
人工智能·算法·开源
SoftLipaRZC35 分钟前
C语言自定义类型:联合和枚举完全指南
c语言·算法