最大公约数和最小公倍数数(GCD&LCM)

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);
}

 

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值