【C语言】一篇博客带你弄懂最大公约数和最小公倍数

目录

  • 前言
  • 什么是最大公约数和最小公倍数
  • 最大公约数与最小公倍数的公式
  • 求最大公约数方法
    • 方法一:暴力穷举法
    • 方法二:辗转相除法
    • 方法三:更相减损术
  • 求最小公倍数的方法
    • 方法一:公式法
    • 方法二:暴力穷举法
    • 方法三:叠乘法
  • 最后总结

前言

我们在C语言的学习中,经常会遇到这样一些数学题目,良好掌握这些题目有利于我们理解和学习C语言,话不多说,直接进入主题

什么是最大公约数和最小公倍数

最大公约数:

首先我们举个例子,比如12 和16,12的约数有(1,2 ,3,4,6,12),16的约数有(1,2,4,8,16)公约数就是两个数共同的约数,(1,2,4)而公约数中最大的就是最大公约数。

最小公倍数

我们同样举个例子,比如12和16,我们将163=48,124=48,这是两个数第一次有倍数相等关系,就叫48是最小公倍数

最大公约数与最小公倍数的公式

最大公约数 —— Greatest Common Divisor(GCD)
最小公倍数 —— Leatest Common Multiple(LCM)

假设a和b是我们已知的数,那么 就存在一个公式。
公式展示

【C语言】一篇博客带你弄懂最大公约数和最小公倍数

这与我们的路程公式很相似,我们可以类比记忆,路程=速度*时间
所以我们只要求出其中的一个就行,求出GCD 就可以通过公式求出LCM,
求出LCM就可以通过公式求出GCD。

求最大公约数方法

方法一:暴力穷举法

细节讲解: 我们知道最大公约数是约数中能同时整除两数,并且是最先整除的,那我们就可以一个一个试。我们可以将l两个数中小的那个赋给tmp,为什么呢?因为我们找最大公倍数时最大也不会超过a,b两个数中最小的那个
比如16 和12 ,我们肯定是从12往下找,而不是还要在16~12之间浪费时间。 我们来看看代码

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int tmp = a > b ? b : a;
	while (1)
	{
		if (a % tmp == 0 && b % tmp == 0)
		{
			printf("最大公约数是%d", tmp);
			break;
		}
		else
		tmp--;
	}
	return 0;
}

方法二:辗转相除法

在数学中,辗转相除法,又称欧几里得算法(Euclidean algorithm),是求取最大公约数的一种算法。辗转相除法首次出现于欧几里得的《几何原本》中的第Ⅶ卷,书中的命题ⅰ和命题ⅱ所描述的就是辗转相除法,而在中国,辗转相除法最早出现在《九章算法》中。可以说这是一个非常经典的方法

我们来看流程图

解析:如果我们有a,b a = 24 b = 18 ,我们先让 24 % 18 = 6 ,
接下来我们让 18 % 6 = 0 ;刚好符合我们流程图中蓝色框框的条件,这样就能确定 6 就是最大公倍数。如果是18 % 24 呢?

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	while (1)
	{
		int c = a % b;
		if (0 == a % b)
		{
			printf("%d就是最大公约数", b);
			break;
		}
		else
		{
			a = b ; 
			b = c;
		}
	}
	return 0;
}

方法三:更相减损术

《九章算术》是中国古代的数学专著,其中的“更相减损术”可以用来求两个数的最大公约数

流程图:

用更相减损术求98与63的最大公约数。

我们只要跟着流程图走,然后一直改变 a 和 b 的值然后直至a b 相等就行,a b 相等时的那个数就是最大公倍数,下面给出代码

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	while (1)
	{
		if (a == b)
		{
			printf("最大公倍数是%d", a);
			break; 
		}
		if (a > b)
		{
			a = a - b;
		}
		if (b > a)
		{
			b = b - a;
		}
	}
	return 0;
}

求最小公倍数的方法

方法一:公式法

【C语言】一篇博客带你弄懂最大公约数和最小公倍数

所以我们只要求出其中的一个就行,求出GCD 就可以通过公式求出LCM,
我们上面已经介绍了三种求GCD的方法,直接用公式也是可以的。

方法二:暴力穷举法

我们知道最小公倍数就是能够同时整除我们已知的两个数的数,而且我们可以从两个数中更大的开始,比如说求45和30的最小公倍数。
我们肯定是从45 往上找。
由于方法比较暴力我们就直接看代码吧!

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int c = a > b ? a : b;
	while (1)
	{
		if (0 == c % a && 0 == c % b)
		{
			printf("最小公倍数是%d", c);
			break;
		}
		
		c++;
	}
	return 0;
}

方法三:叠乘法

方法讲解:
已知两个数的公倍数一定与这两个数存在倍数关系,那么求解最小公倍数我们就可以将其中一个数依次扩大1倍、2倍、3倍……直到出现第一个扩大n倍的数可以同时整除这两个数,这个数就是最小公倍数。

计算36和270的最小公倍数

我们直接给出代码

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	
	int i = 1;
	while (a * i % b != 0)
	{
		i++;
	}
	printf("最小公倍数是%d", a * i);
	return 0;

}

最后总结

通过这篇博客我们知道了求最大公约数和最小公倍数的许多方法,当然不止这些方法,但是我觉得这些应该够用一段时间了。我是一个博客新手,本文若是有笔误之处,请大家多多指出。最后写博客是一件很辛苦但是很有成就感的一件事情。

这篇文章到这里就结束了,如果有帮到你就请点个赞吧。我的博客是不添加水印的,大家也可以用里面的图片。最后就麻烦用你的小手点个赞吧,哈哈Thanks♪(・ω・)ノ

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
乘风的头像乘风管理团队
上一篇 2023年12月26日
下一篇 2023年12月26日

相关推荐