QQ登录

只需一步,快速开始

开启左侧

欧几里得算法

  [复制链接]
18062232277 发表于 2024-4-19 08:35:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
欧几里得算法又称辗转相除法,是指用于计算两个非负整数a,b的最大公约数应用领域有数学和计算机两个方面。计算公式gcd(a,b) = gcd(b,a mod b)。
两个整数的最大公约数是能够同时整除它们的最大的正整数。辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。
7782c471f50f642a524d9e609f1c3ee0.jpg
欧几里得算法和扩展欧几里得算法可使用多种编程语言实现。








{38ADC14A-5160-4107-B9E3-10F290DBB692}.jpg

 楼主| 18062232277 发表于 2024-4-19 08:37:07 | 显示全部楼层
算法简介
欧几里得算法是用来求两个正整数最大公约数的算法。古希腊数学家欧几里得在其著作《The Elements》中最早描述了这种算法,所以被命名为欧几里得算法。
扩展欧几里得算法可用于RSA加密等领域。
假如需要求 1997 和 615 两个正整数的最大公约数,用欧几里得算法,是这样进行的:
1997 ÷ 615 = 3 (余 152)
615 ÷ 152 = 4(余7)
152 ÷ 7 = 21(余5)
7 ÷ 5 = 1 (余2)
5 ÷ 2 = 2 (余1)
2 ÷ 1 = 2 (余0)
至此,最大公约数为1
除数余数反复做除法运算,当余数为 0 时,取当前算式除数为最大公约数,所以就得出了 1997 和 615 的最大公约数 1。


 楼主| 18062232277 发表于 2024-4-19 08:37:47 | 显示全部楼层
计算证明
其计算原理依赖于下面的定理:
定理:两个整数的最大公约数等于其中较小的那个数和两数相除余数的最大公约数。最大公约数(Greatest Common Divisor)缩写为GCD
gcd(a,b) = gcd(b,a mod b) (不妨设a>b 且r=a mod b ,r不为0)

证法一

a可以表示成a = kb + r(a,b,k,r皆为正整数,且r不为0)
假设d是a,b的一个公约数,记作d|a,d|b,即a和b都可以被d整除。
而r = a - kb,两边同时除以d,r/d=a/d-kb/d,由等式右边可知m=r/d为整数,因此d|r
因此d也是b,a mod b的公约数。
因(a,b)和(b,a mod b)的公约数相等,则其最大公约数也相等,得证。

证法二

假设c = gcd(a,b),则存在m,n,使a = mc, b = nc;
令r = a mod b,即存在k,使r = a-kb = mc - knc = (m-kn)c;
故gcd(b,a mod b) = gcd(b,r) = gcd(nc,(m-kn)c) = gcd(n,m-kn)c;
则c为b与a mod b的公约数;
假设d = gcd(n,m-kn), 则存在x,y, 使n = xd, m-kn = yd; 故m = yd+kn = yd+kxd = (y+kx)d;
故有a = mc = (y+kx)dc, b = nc = xdc; 可得 gcd(a,b) = gcd((y+kx)dc,xdc) = dc;
由于gcd(a,b) = c, 故d = 1;
即gcd(n,m-kn) = 1, 故可得gcd(b,a mod b) = c;
故得证gcd(a,b) = gcd(b,a mod b).
注意:两种方法是有区别的。


 楼主| 18062232277 发表于 2024-4-19 08:38:20 | 显示全部楼层
本帖最后由 18062232277 于 2024-4-19 10:19 编辑

程序设计
辗转相除法是利用以下性质来确定两个正整数 a 和 b 的最大公因子的:
⒈ 若 r 是 a ÷ b 的余数,且r不为0, 则
gcd(a,b) = gcd(b,r)
⒉ a 和其倍数之最大公因子为 a。
另一种写法是:
⒈ 令r为a/b所得余数(0≤r)
若 r= 0,算法结束;b 即为答案。
⒉ 互换:置 a←b,b←r,并返回第一步。

{38ADC14A-5160-4107-B9E3-10F290DBB692}.jpg
 楼主| 18062232277 发表于 2024-4-19 08:51:44 | 显示全部楼层
本帖最后由 18062232277 于 2024-4-19 08:53 编辑

算法版本

C++版


QQ截图20240419085113.jpg
 楼主| 18062232277 发表于 2024-4-19 08:56:11 | 显示全部楼层
Python

11.jpg
 楼主| 18062232277 发表于 2024-4-19 09:27:53 | 显示全部楼层
在Scratch编程语言中,可以通过使用变量和循环结构来实现欧几里得算法。以下是一个简单的Scratch脚本实现欧几里得算法:
  • 首先,创建两个变量,比如叫做num1和num2,用于存储要计算最大公约数的两个数。
  • 接着,创建一个循环,这个循环会一直执行,直到num2变为0。在循环的每一次迭代中,计算num1除以num2的余数,并将这个余数存储在一个新的变量中,比如叫做remainder。
  • 然后,将num2的值赋给num1,将remainder的值赋给num2。
  • 当num2变为0时,循环结束,此时的num1的值就是两个数的最大公约数。
注意,Scratch没有直接的除法运算和取余运算,但你可以使用"math"分类下的"mod"运算来获取余数,使用"divide"运算来获取商。但是在这个算法中,我们只需要余数,所以只需要使用"mod"运算。

5.jpg

 楼主| 18062232277 发表于 2024-4-19 09:29:26 | 显示全部楼层
22.jpg
客服热线
400-1234-888 周一至周日:09:00 - 21:00
公司地址:襄阳市樊城区长虹路现代城5号楼188

创客帮MAKER.BAND青少年创客创意社区是一个融教育、科技、体育资讯为一体的综合服务平台,专注于教育创新、专注于科技体育、专注于教育资讯。

Powered by Discuz! X3.4 © 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表