最大公约数的三种求法——(C语言)

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

如何求解最大公约数,首先了解什么是最大公约数,如果有一个自然数a能被自然数b整除,则称a为b的倍数,b为a的约数。几个自然数公有的约数,叫做这几个自然数的公约数。公约数中最大的一个公约数,称为这几个自然数的最大公约数。

例: 在2、4、6中,2就是2,4,6的最大公约数。

再C语言中,有以下三种求法:


方法一:

int main() {
	int a;
	int b;
	printf("请输入两个正整数:");
	scanf("%d %d", &a, &b);
	int i = 0;
	int m = 0;
	for (i = 1; i <= a && i <= b; i++) {
		if (a % i == 0 && b % i == 0) {
			m = i;
		}
	}
	printf("最大公约数为:%d\n", m);
		return 0;
}

 该方法是将两个数依次对1开始取模,往后++,直到满足两个都对i取模为0结束。


方法二:

int main() {
	int a;
	int b;
	printf("请输入两个正整数:");
	scanf("%d %d", &a, &b);
	//找到两个数的较小者
	int min = (a < b ? a : b);
	while (1) {
		if (a % min == 0 && b % min == 0) {
			break;
		}
		min--;
	}
	printf("最大公约数为:%d\n", min);
	return 0;
}

 该方法是找到两个数的较小者,输入的两个数依次对较小者取模,满足上述条件结束。


 方法三:

//辗转相除法
int main() {
	int a;
	int b;
	printf("请输入两个正整数:");
	scanf("%d %d", &a, &b);
	int k = 0;
	while (k = a % b) {
		a = b;
		b = k;
	}
	printf("最大公约数为:%d\n", b);
	return 0;
}

 辗转相除法一般指欧几里得算法。欧几里得算法又称辗转相除法,是指用于计算两个非负整数a,b的最大公约数。那么辗转相除法的原理是什么?

1、 原理:设两数为a、b(ab),用gcd(a,b)表示a,b的最大公约数,r=a(mod b)为a除以b的余数,k为a除以b的商,即a÷b=k。。。。。。。r。辗转相除法即是要证明gcd(a,b)=gcd(b,r)。

2、 第一步:令c=gcd(a,b),则设a=mc,b=nc。

3、 第二步:根据前提可知r=a-kb=mc-knc=(m-kn)c。

4、 第三步:根据第二步结果可知c也是r的因数。

5、 第四步:可以断定m-kn与n互质(假设m-kn=xd,n=yd(d1),则m=kn+xd=kyd+xd=(ky+x)d,则a=mc=(ky+x)cd,b=nc=ycd,则a与b的一个公约数cdc,故c非a与b的最大公约数,与前面结论矛盾),因此c也是b与r的最大公约数。

6、 从而可知gcd(b,r)=c,继而gcd(a,b)=gcd(b,r)。

7、 证毕。以上步骤的操作是建立在刚开始时r≠0的基础之上的。即m与n亦互质。

8、 解释:辗转相除法,又名欧几里德算法(Euclidean algorithm)乃求两个正整数之最大公因子的算法。它是已知最古老的算法,其可追溯至公元前300年前。

9、 来源:设两数为a、b(ab),求a和b最大公约数(a,b)的步骤如下:用a除以b,得a÷b=q。。。。。。r1(0≤r1)。若r1=0,则(a,b)=b;若r1≠0,则再用b除以r1,得b÷r1=q。。。。。。r2(0≤r2)。若r2=0,则(a,b)=r1,若r2≠0,则继续用r1除以r2,……如此下去,直到能整除为止。其最后一个余数为0的除数即为(a, b)的最大公约数。

10、 例如:a=25,b=15,a/b=1。。。。。.10,b/10=1。。。。。.5,10/5=2。。。。。。.0,最后一个余数为0d的除数就是5, 5就是所求最大公约数。文章来源地址https://www.toymoban.com/news/detail-434375.html


“只有两种编程语言:大家抱怨的和没人用的。”——本贾尼·斯特劳斯特鲁普(Bjarne Stroustrup)

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

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

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

相关文章

  • 【C语言】辗转相除法求最大公约数(详解)

    辗转相除法(又称欧几里德算法)是一种用于求解两个整数的最大公约数的方法。本文将使用C语言来实现辗转相除法,并对其原理进行解释。 辗转相除法的原理非常简单。假设有两个整数a和b,其中a b。通过对a除以b求余数,得到余数r1。然后把b除以r1求余数,得到余数r2。如

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

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

    2024年02月04日
    浏览(46)
  • C语言入门——求最大公约数(2种方法超详细)

    基本介绍: 最大公约数(greatest common divisor,简写为 gcd ;或highest common factor,简写为hcf),指某几个整数共有因子中最大的一个。 最大公约数 能够整除一个整数的整数称为其的约数(如5是10约数); 能够被一个整数整除的整数称为其的倍数(如10是5的倍数); 如果一个数既

    2024年02月08日
    浏览(101)
  • 【c语言】—求最大公约数和最小公倍数多种方法

    目录 一.求最大公约数 1.枚举法求最大公约数 2.辗转相除法 二.求最小公倍数 1.枚举法求最小公倍数 2.简易法 3.公式法 思路:先求两个数中的最小值,最大公约数不可能大于两个数的最小数 比如6和18,最大公约数就是6 再如3和9,最大公约数就是3 然后再从1开始循环遍历到最小

    2024年02月08日
    浏览(59)
  • C语言经典算法之Euclidean算法求最大公约数

    目录 前言 A.建议 B.简介 一 代码实现 二 时空复杂度 A.循环实现 a.时间复杂度(Time Complexity): b.空间复杂度(Space Complexity): B.递归实现 a.时间复杂度(Time Complexity): b.空间复杂度(Space Complexity): 三 优缺点 A.循环实现 a.优点: b.缺点: c.总结: B.递归实现 a.优点:

    2024年03月26日
    浏览(55)
  • 【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语言:给定两个数,求这两个数的最大公约数(新思路:辗转相除法)

    从键盘 输入两个数 , 求 这 两个数 的 最大公约数 。                       =========================================================================                         (一). 生成 相关变量 ; 从键盘 输入两个数 ; 再 使用 三目操作符(条件操作符) 找出 较小值 。        

    2024年02月09日
    浏览(46)
  • 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

领红包