最大公因数,最小公倍数详解
创作时间:
作者:
@小白创作中心
最大公因数,最小公倍数详解
引用
CSDN
1.
https://blog.csdn.net/Tokai___Teio/article/details/134944351
前言
对于初学编程的小伙伴们肯定经常遇见此类问题,而且为之头疼,今天我来给大家分享一下,最大公因数和最小公倍数的求法。让我们开始吧!
1. 最大公因数
首先提起最大公因数大家最先想到的就是辗转相除法。
假如求a,b的最大公因数x。其中a>b。a可以表示为nb+t,那么t=a-nb,因为x是a和b的公因数,将等式两边同时除以x得,t/x=a/x-n*b/x,那么我肯可以知道t/x是个整数,所以x是a和a%b的公因数,那么我们可知那么x也是b和a%b的公因数。所以a和b的最大公约数和b和a%b的最大公约数是一样的。那么我们就可以使用循环的方法求出最大公因数如下:
法1
#include<stdio.h>
int gcd(int a, int b)
{
if (a > b)//判断大小事大数除以小数
{
int temp = a;
a = b;
b = temp;
}
while (a % b)//辗转相除
{
int temp = a;
a = b;
b = temp%b;
}
return a;
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
int ans = gcd(a,b);
printf("%d", ans);
return 0;
}
那么这样写有点麻烦,我们可以直接使用递归的方法解决而且速度更快。
法2
#include<stdio.h>
int gcd(int a, int b)
{
if (a == 0)//当a为0时,b为最大公因数
return b;
return gcd(b, a%b);
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
if(a>b)
int tem = a;
a = b ;
b = tem;
int ans = gcd(a,b);
printf("%d", ans);
return 0;
}
那么有没有更快的方法呢?当然有!我们都知道位运算的速度比除法运算快的多,那么我肯可以吧代码改成这样。切记,a要大于b才能使用。
法3
#include<stdio.h>
int gcd(int a, int b)
{
while (b ^= a ^= b ^= a %= b);//连等式是从右往左计算的,我们要知道a^a=0,a^0=a。那么连等式就可以等同于gcd(b,a%b)
return a;
}
int main()
{
int a, b;
scanf("%d %d", &a, &b);
int ans = gcd(a,b);
printf("%d", ans);
return 0;
}
这种算法是最快的
2. 最小公倍数
正常求法求最小公倍数可能太过麻烦,但是我们要知道一个定理。假设x是a和b的最大公因数,y是a和b的最小公倍数,那么x * y=a * b。(如果不明白可以百度一下或者直接背下来当结论用)
所以我们就可以用上面的方法先求出x然后再用y=a * b/x求出y的值。
3. 尾声
本期的分享到这里结束,如果觉得博主讲的不错的话请给博主一个点赞一个收藏支持一下,我们下期再见!
热门推荐
双星系统中的行星可能是宜居的,但它们的形成方式不同
C71500铜合金:高性能铜基合金的创新设计与应用
拥抱“大黄山”,奏响“天柱乐章”
AI 辅助的竞争对手分析:揭秘人工智能在市场竞争中的应用
产品失效模式与效益分析(DFMEA)的实际应用
肉苁蓉的性味归经功效与作用
回表、聚簇索引和非聚簇索引详解
从《西门豹治邺》中得到的启示
绩效考评方法中行为锚定等级评价法是什么?
排隐患 筑屏障 恩施州高效推进工伤预防调研
机器学习之方差与标准差
在NAS上轻松部署Home Assistant,实现全方位智能家居管理
新华社关注!雄安:“未来之城”阔步走来
如何成功申请国际专利,全面指南与步骤解析
田姓的起源与历史变迁:田姓的文化传承与现代分布
未来已来:智能机器人如何重塑我们的日常生活?
揭秘中国历史:真实的高渐离形象探微
香蕉用什么催熟最快最好
为什么不少人说广州南站的选址是超前眼光和世界一流的?
如何提升工程质量管理的效果?
防癌症买什么保险较好线下买
Word行距怎么设置?Word中调整行距的6种方法详解
交流电路功率详解:有功功率、无功功率与视在功率
人文社科类包括哪些专业?这九大领域助你解锁社会洞察力!
年轻人的第一台国产摩托车,该怎么选?
开封人舌尖上的春日“食光”
帕累托法则在各行业中的实践应用
解读《月亮与六便士》:书中蕴含三层象征意义,理想与现实的纠纷
干货!职场升迁的隐秘法则:是能力决定一切,还是人际关系?
中医治疗脑梗的有效方法及专家推荐