【c语言】—求最大公约数和最小公倍数多种方法

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

目录

一.求最大公约数

1.枚举法求最大公约数

2.辗转相除法

二.求最小公倍数

1.枚举法求最小公倍数

2.简易法

3.公式法


一.求最大公约数

1.枚举法求最大公约数

思路:先求两个数中的最小值,最大公约数不可能大于两个数的最小数

比如6和18,最大公约数就是6

再如3和9,最大公约数就是3

然后再从1开始循环遍历到最小值的数中找最大公约数即可,因为1是最小的因子了,0不能作为除数

#include<stdio.h>

int main()
{
	int a = 0;
	int b = 0;
	int ret = 0;
	scanf("%d %d", &a, &b);
	int min = a < b ? a : b;
	for (int i = 1; i <= min; i++)
	{
		if (a % i == 0 && b % i == 0)
		{
			ret = i;
		}
	}
	printf("最大公约数是%d\n", ret);
	return 0;
}

2.辗转相除法

#include<stdio.h>

int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	while (b)
	{
		int t = a % b;
		a = b;
		b = t;
//比如a=12,b=18 第一次t=12 a=18 b=12.第二次t=6 a=12 b=6 第三次t=0 a=6 b=0循环终止,所以最大公约数是6
	}
	printf("最大公约数是%d\n", a);
	return 0;
}

二.求最小公倍数

1.枚举法求最小公倍数

思路:求两个数中的最大值,因为最小公倍数肯定 >= 两个数中的最大值

那比如6和12,最小公倍数就是12了

再如5和10,最小公倍数就是10了

值得注意的是他与最大公约数有所不同,最大公约数是遍历到两个数的“最小值”,而最小公倍数是从两个数中的最大值开始遍历,最小公倍数只要找到一个满足条件的公倍数,立马结束循环,(如果不符合条件再++即可)因为你要求的是最小的公倍数

#include<stdio.h>

int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int max = a > b ? a : b;
	while (1)
	{
		if (max % a == 0 && max % b == 0)
			break;
    //一旦找到满足条件的因子就跳出循环
    //因为这里求的是最小公倍数
		else max++;

	}
	printf("最小公倍数是%d\n", max);
    return 0;
}

2.简易法

因为最小公倍数应该为两个数共同的倍数,所以我们可以用其中的第一个数的整数倍对第二个数整除,如果第一个数的整数倍也能整除第二个数,说明第一个数的整数倍就是两个数共同的倍数,那么找到这一个了(第一次找到的公倍数)就是最小公倍数了,那么break跳出循环即可

#include<stdio.h>

int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int i = 0;
	for (i = 1; ; i++)
	{//i=1,2...表示a的几倍,保证了是a的倍数, a*i就可以表示为最小公倍数
		if (a * i % b == 0)
		{
			printf("%d\n", a * i);
			break;
		}
	}
	return 0;
}

3.公式法

用已知最大公约数求最小公倍数就可以,已知两个数a,b,最大公约数是c,则最小公倍数是a*b / c,即先求出最大公约数,两个数相乘再除以最大公约数即最小公倍数文章来源地址https://www.toymoban.com/news/detail-716685.html


#include<stdio.h>

int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	//保存a和b值,因为下面求最小公倍数用到a和b
	int tmpa = a, tmpb = b;
	while (b)
	{
		int t = a % b;
		a = b;
		b = t;
	}
	//此时tmpa和tmpb才是原来的值,a已经为最大公约数
	printf("最小公倍数是%d\n", tmpa * tmpb / a);
	return 0;
}

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

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

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

相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2023年04月21日
    浏览(30)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包