Euclid算法

王朝百科·作者佚名  2009-11-05  
宽屏版  字体: |||超大  

gcd(a,b)=gcd(b, a+kb) a,b,k为任意整数

􀂨gcd(a,b)=gcd(b, a mod b) a≥0,b>0

• Example:gcd(55,22)=gcd(22, 55mod22)

=gcd(22,11)=11

• 证明:假定d=gcd(a,b),那么有d|a和d|b.对任何正整数b,a

可表示为如下形式: a=kb+r ≡r mod b, a mod b =r , 因

此,有(a mod b )= a-kb,k为某个整数。但由于d|b,b也

能整除kb, 而d|a,故有d|(a mod b), 这表明d 也是b 和(a

mod b) 的公因子。由于这是可逆的,如果d 是b 和(a mod

b) 的公因子,那么d|kb,且d|[kb+(a mod b)],这等同于

d|a。这样a和b的公因子集合等同于b 和(a mod b) 的公因

子集合。

 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
© 2005- 王朝百科 版权所有