1.GCD的定义
GCD 即最大公约数Greatest Common Divisor。整数 a 和 b 的最大公约数是指能同时整除 a 和 b 的最大整数,记为 gcd(a,b)。
2.GCD的性质
1) gcd(a,b)=gcd(a,a+b)=gcd(a,k⋅a+b)
2) gcd(ka,kb)=k⋅gcd(a,b)。
3) 多个整数的最大公约数:gcd(a,b,c)=gcd(gcd(a,b),c)。
4) 若 gcd(a,b)=d,则 gcd(a/d,b/d)=1,即 a/d=与 b/d=互素。这个定理很重要哦!
5) gcd(a+cb,b)=gcd(a,b)
3.GCD的实现
在c++标准库中有__gcd(a,b)直接用,但是参数a和b都是正整数,否则会返回负数。
若自己实现代码如下:
int gcd(int x,int y){
return y?gcd(y,x%y):x;
}
4.最小公倍数LCM的定义
两个或多个整数公有的倍数叫做它们的公倍数,其中除0以外最小的一个公倍数就叫做这几个整数的最小公倍数。整数a,b的最小公倍数记为lcm(a,b)
5.最大公因数和最小公倍数之间的性质
两个自然数的乘积等于这两个自然数的最大公约数和最小公倍数的乘积。最小公倍数的计算要把三个数的公有质因数和独有质因数都要找全,最后除到两两互质为止。
6.LCM的实现
int lcm(int a,int b){
return a*b /gcd(a,b);
}