求最小公倍数的3种方法(C语言)

这篇具有很好参考价值的文章主要介绍了求最小公倍数的3种方法(C语言)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

最小公倍数是什么呢?它是指能同时整除a和b的最小正整数,比如,3和7的公倍数有21,42,84等,21就是最小公倍数。

下面介绍3种方法来求最小公倍数。

1.辗转相除法:a和b的最小公倍数=a*b/(a和b的最大公约数)

#include <stdio.h>
int main()
{
	int m = 0;
	int n = 0;
	int a = 0;
	scanf("%d %d",&m,&n);
	int x = m * n;
	while (a = m % n)//求两个数的最大公约数
	{
		m = n;
		n = a;
	}
	printf("%d\n",x/n);	
	return 0;
}

 2.a和b的最小公倍数,随便拿一个数,比如a,由小到大找出a的倍数,这其中肯定也有b的倍数,最小的那一个即为a和b的最小公倍数(拿出b同理)

#include <stdio.h>
int main()
{
	int m = 0;
	int n = 0;
	scanf("%d %d",&m,&n);
	int i = 1;
	while (m * i % n != 0)
	{
		i++;
	}
	printf("%d\n",i*m);
	return 0;
}

 3.(最矬的方法)找出a和b中最大的那一个,赋值给m,然后m自增1,如果某个m第一次既能整除a又能整除b,那么这个m即为最小公倍数。

#include<stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d",&a,&b);
	int m = a > b ? a : b;//找出a和b的最大值
	while (1)
	{
		if ((m % a == 0) && (m % b == 0))
		{
			break;
		}
		m++;
	}
	printf("%d\n",m);
	return 0;
}

 以上三个方法中,方法1和2比较优秀,方法3效率低下,因为需要逐个值查找。

码字不易,如果各位看官还算满意,一键三连支持一下呗~文章来源地址https://www.toymoban.com/news/detail-735475.html

到了这里,关于求最小公倍数的3种方法(C语言)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C语言—最大公约数和最小公倍数

    作者主页: paper jie的博客_CSDN博客-C语言,算法详解领域博主 本文作者: 大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于 《算法详解》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将算法基础知识一网打尽,希望

    2024年02月13日
    浏览(42)
  • 最小公倍数Python——三种方法

    最小公倍数 = 两数的乘积 / 最大公约数 这种方法的实现原理是求两个正整数的余数 r ,再用两个正整数中的较小数与其再求余直到余数为 0 时,此时的较小数就是最大公约数。最后利用公式计算得到这两个数的最小公倍数。 代码示例: 这种方法比较易于理解,原理是先判断

    2024年04月14日
    浏览(33)
  • 【C语言】求最大公约数和最小公倍数

    方法一:利用 定义法 求最大公因数和最小公倍数 方法二:最小公倍数求法同上, 最大公约数方法不同 方法一方法二的结果示例如下   方法三:利用 辗转相除法 求最大公约数和最小公倍数 法(1)结果示例如下:  法(2)示例结果如下:  以上就是用C语言循环和循环之前的

    2024年02月07日
    浏览(53)
  • 【C语言】两个整数最大公约数和最小公倍数

    输入两个整数,求这两个数的最大公约数和最小公倍数。 第一种求法(辗转相除法)这个方法代码较洁简,我也比较推荐就是刚开始有点比较难了解。 首先,来看看怎么求最大公约数,求最大公约数需要用到 欧几里得算法 ,也称为辗转相除法。算法就是用两数中较大的数

    2024年02月04日
    浏览(47)
  • 最小公倍数求法 (3种代码思路供参考 ) --(C语言实现)-- 详解

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 正整数A和正整数B的最小公倍数是指 能被A和B整除的最小的正整数值,设计一个算法,求A,B的最小公倍数 输入: 输入两个正整数A,B 输出: 输出:A,B的最小公倍数 1、最小公倍数(LCM)是:能被A和B整除的最

    2024年02月06日
    浏览(44)
  • C++求最大公约数和最小公倍数的方法

    每次遇到最大公约数和最小公倍数时总是忘记,这里总结了两种求最大公约数和最小公倍数的方法。 欧几里得算法是求解两个数的最大公约数的一种常用方法。该算法基于以下原理:两个整数的最大公约数等于其中较小数和两数的余数之间的最大公约数。可以通过递归调用该

    2024年02月15日
    浏览(45)
  • 【C语言】一篇博客带你弄懂最大公约数和最小公倍数

    我们在C语言的学习中,经常会遇到这样一些数学题目,良好掌握这些题目有利于我们理解和学习C语言,话不多说,直接进入主题 最大公约数: 首先我们举个例子,比如12 和16,12的约数有(1,2 ,3,4,6,12),16的约数有(1,2,4,8,16)公约数就是两个数共同的约数,(1,2,4)而公约数

    2024年02月04日
    浏览(48)
  • C语言——输入两个正整数m和n,求其最大公约数和最小公倍数

    目录 1.最大公约数求法 1.1辗转相除法 1.2相减法 2.最小公倍数求法 3.代码实现 4.结果展示 1.1辗转相除法 设有两整数a和b: a%b得余数c 若c==0,则b即为两数的最大公约数 若c!=0,则a=b,b=c,再回去执行第一步。 例如:求27和15的最大公约数过程为: 27÷15 余12 15÷12 余3 12÷3 余0 因

    2024年02月01日
    浏览(43)
  • C语言——输入两个正整数 m 和 n。求其最大公约数和最小公倍数。

    1、首先,程序通过printf函数提示用户输入两个正整数m和n,然后使用scanf函数接收用户的输入并将值分别存储到变量m和n中。 2、接下来,程序进入一个for循环,从1开始遍历直至i等于较小的数(m或n),检查当前数值i是否能同时整除m和n。如果i既能被m整除又能被n整除(即满足

    2024年02月03日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包