【C语言】求最大公约数和最小公倍数

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

方法一:利用定义法求最大公因数和最小公倍数

#include<stdio.h>
int main()
{
	int a,b,i,j;
	int max=0;
	scanf("%d%d",&a,&b);
	for(i=a;;i++)//求最小公倍数
	{
		if(i%a==0&&i%b==0)//用大于等于a和b的数i(i大于等于a和b,无上限)分别除以a和b,同时除尽的第一个数即为最小公倍数
		break;//然后循环结束
	}
	
	for(j=1;j<=a;j++)//求最大公约数
	{
		if(a%j==0&b%j==0)//让a和b分别除以j(j从一开始,j有上限要小于等于a或b)
//利用j++,如果a和b能同时除尽j
		{
			if(max<j)//再判断j是不是小于a或b的最大公约数,不是则赋值最大值
			max=j;//这样求出来的max即为最大公约数
		}
		
	}
	printf("%d %d\n",i,max);//最后最大公约数用max表示了
	return 0;
} 

方法二:最小公倍数求法同上,最大公约数方法不同

#include<stdio.h>
int main()
{
	int a,b,i,j;
	int max=0;
	scanf("%d%d",&a,&b);
	for(i=a;;i++)
	{
		if(i%a==0&&i%b==0)//求最小公倍数(方法同法一) 
		break;
	}

	for(j=a;;j--)//求最大公约数
	{
		if(a%j==0&&b%j==0)//还是用a和b除以j(j直接赋值为a或b,示例赋值为a(b也可以的))
//利用j--,第一个a和b同时除尽的数j即为最大公约数
		break;//然后直接结束循环即可
	}
	printf("%d %d\n",i,j);
	
	return 0;
} 

方法一方法二的结果示例如下

c语言求最大公约数和最小公倍数,c语言

 

方法三:利用辗转相除法求最大公约数和最小公倍数

#include<stdio.h>
	int main(void)
	{  
	  int m,n,t,a,b;
	  t=0;
	  scanf("%d %d",&m,&n);
	  a=m;
	  b=n;//先把m和n分别赋值给a和b,用来求最小公倍数

      //法(1)
	  /*
        while(t=m%n,t!=0)//限制条件有两个
    //求出最小公约数和最大公倍数的数值与m和n大小无关,所以不用考虑是m%n还是n%m,结果一样
		{
			m=n;
			n=t;
		}
		printf("最大公约数是:%d\n",n);//最后n为最大公约数
		printf("最小公倍数是:%d\n",a/n*b);
       */

      //法(2)
    while (n != 0)//一个限制条件
	{
		t = m % n;//t的赋值在限制条件里面
		m = n;
		n = t;
	}
	printf("最大公约数是:%d\n", m);//最后m为最大公约数
	printf("最小公倍数是:%d\n", a / m * b);
//最小公倍数求法和上边一样(除以n(最大公因数)变成除以m)


       return 0;
	}

法(1)结果示例如下:

c语言求最大公约数和最小公倍数,c语言

 法(2)示例结果如下:

c语言求最大公约数和最小公倍数,c语言

 以上就是用C语言循环和循环之前的章节知识总结的最大公约数和最小公倍数的求法,也可以利用函数来求公因数和公倍数,但核心部分还是一样的啊。文章来源地址https://www.toymoban.com/news/detail-731445.html

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

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

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

相关文章

  • 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日
    浏览(46)
  • 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日
    浏览(47)
  • 最大公约数和最小公倍数问题

    等差数列 蓝桥杯192 gcd问题 题目描述 数学老师给小明出了一道等差数列求和的题目。但是粗心的小明忘记了一 部分的数列,只记得其中 N 个整数。 现在给出这 N 个整数,小明想知道包含这 N 个整数的最短的等差数列有几项? 思路:求出每一项之差的最大公约数,以这个

    2023年04月09日
    浏览(41)
  • C++ 最大公约数与最小公倍数

    (一)简单的两个正整数  求 最大公约数 (引入专题) 思路: 根据 “欧几里得算法”  ,即 “辗转相除法” 原理如下: 题意: 求出   a  , b  两个正整数的最大公约数 设  k = a / b,   r = a % b 即    a = k * b + r 又设  d  为 a 和 b 的一个公约数 那么由  r = a - k * b,  可

    2024年02月06日
    浏览(48)
  • P1029 最大公约数和最小公倍数问题

    3 2 1 上题目链接: P1029 [NOIP2001 普及组] 最大公约数和最小公倍数问题 本小蒟蒻的原始思路就是枚举所有范围内的数,分别求出他们的最大公约数和最小公倍数,再看是否满足题意。 于是就有了以下一言难尽的东西(;′⌒`)↓ 皇天不负有心人,收到了2个TLE,其他全WA 自我反

    2024年02月19日
    浏览(40)
  • 【Python 随练】求最大公约数和最小公倍数

    输入两个正整数 m 和 n,求其最大公约数和最小公倍数。 在本篇博客中,我们将解决一个常见的数学问题:求两个正整数的最大公约数和最小公倍数。我们将提供问题的解析,并给出一个完整的代码示例来计算最大公约数和最小公倍数。 给定两个正整数m和n,我们需要求它们

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

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

    2024年02月15日
    浏览(47)
  • 求其最大公约数和最小公倍数,一行代码完成

    题目:输入两个正整数 m 和 n,求其最大公约数和最小公倍数。 求出最大公约数就行,最小公倍数用m*n除以最大公约数就行

    2024年02月05日
    浏览(71)
  • 左手Python 右手R —— 最大公约数和最小公倍数

      此专栏为python与R语言对比学习的文章;以通俗易懂的小实验,带领大家深入浅出的理解两种语言的基本语法,并用以实际场景!感谢大家的关注,希望对大家有所帮助。   “博观而约取,厚积而薄发!”谨以此言,望诸君共勉   本文针对数学问题“ 最大公约数、最

    2023年04月21日
    浏览(50)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包