python最大公约数和最小公倍数辗转相除法_求最大公约数与最小公倍数的辗转相除法的证明.....

辗转相除法

「辗转相除法」又叫做「欧几里得算法」,是公元前 300 年左右的希腊数学家欧几里得在他的著作《几何原本》提出的.利用这个方法,可以较快地求出两个自然数的最大公因数,即 HCF 或叫做 gcd.所谓最大公因数,是指几个数的共有的因数之中最大的一个,例如 8 和 12 的最大公因数是 4,记作 gcd(8,12)=4.

在介绍这个方法之前,先说明整除性的一些特点,注以下文的所有数都是正整数,以后不再重覆.

我们可以这样给出整除以的定义:

对於两个自然数 a 和 b,若存在正整数 q,使得 a=bq,则 b 能整除 a,记作 b | a,我们叫 b 是 a 的因数,而 a 是 b 的倍数.

那麼如果 c | a,而且 c | b,则 c 是 a 和 b 的公因数.

由此,我们可以得出以下一些推论:

推论一:如果 a | b,若 k 是整数,则 a | kb.因为由 a | b 可知 ha=b,所以 (hk)a=kb,即 a | kb.

推论二:如果 a | b 以及 a | c,则 a | (b±c).因为由 a | b 以及 a | c,可知 ha=b,ka=c,二式相加,得 (h+k)a=b+c,即 a | (b+c).同样把二式相减可得 a | (b-c).

推论三:如果 a | b 以及 b | a,则 a=b.因为由 a | b 以及 b | a,可知 ha=b,a=kb,因此 a=k(ha),hk=1,由於 h 和 k 都是正整数,故 h=k=1,因此 a=b.

辗转相除法是用来计算两个数的最大公因数,在数值很大时尤其有用而且应用在电脑程式上也十分简单.其理论如下:

如果 q 和 r 是 m 除以 n 的商及余数,即 m=nq+r,则 gcd(m,n)=gcd(n,r).

证明是这样的:

设 a=gcd(m,n),b=gcd(n,r)

则有 a | m 及 a | n,因此 a | (m-nq)(这是由推论一及推论二得出的),即 a | r 及 a | n,所以 a | b

又 b | r 及 b | n,所以 b | (nq+r),即 b | m 及 b | n,所以b | a.因为 a | b 并且 b | a,所以 a=b,即 gcd(m,n)=gcd(n,r).

例如计算 gcd(546,429),由於 546=1(429)+117,429=3(117)+78,117=1(78)+39,78=2(39),因此

gcd(546,429)

=gcd(429,117)

=gcd(117,78)

=gcd(78,39)

=39

最小公倍数就是2个数的积除以最大公约数

作业帮用户

2017-10-24

举报

1. Python计算最大公约数和最小公倍数,通常可以使用辗转相除法(又称欧几里得算法)来实现,代码如下: ```python # 计算最大公约数 def gcd(a, b): if a == 0: return b return gcd(b % a, a) # 计算最小公倍数 def lcm(a, b): return a * b // gcd(a, b) ``` 在这里,我们定义了两个函数,`gcd()` 和 `lcm()`。其中 `gcd()` 函数用于计算最大公约数,`lcm()` 函数用于计算最小公倍数。这两个函数都使用了辗转相除法来实现,在计算最大公约数时,每次将较大的数对较小的数进行取模操作,直到取模的结果为 0,此时较小的数就是最大公约数。而在计算最小公倍数时,可以通过乘积除以最大公约数来得到结果。 2. Python中的集合(set)提供了交、并、差、补等操作。代码如下: ```python # 创建两个集合 set1 = {1, 2, 3} set2 = {2, 3, 4} # 交集 intersection = set1 & set2 # 或者使用 intersection = set1.intersection(set2) print("交集:", intersection) # 并集 union = set1 | set2 # 或者使用 union = set1.union(set2) print("并集:", union) # 差集 difference = set1 - set2 # 或者使用 difference = set1.difference(set2) print("差集:", difference) # 对称差集 symmetric_difference = set1 ^ set2 # 或者使用 symmetric_difference = set1.symmetric_difference(set2) print("对称差集:", symmetric_difference) ``` 在这里,我们创建了两个集合 `set1` 和 `set2`,然后分别计算了它们的交集、并集、差集和对称差集,使用了 `&`、`|`、`-` 和 `^` 等操作符来实现。另外,Python中的集合还提供了许多其他的操作和方法,如子集、超集、添加元素、删除元素等,可以根据具体的需求使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值