栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

辗转相除法得最大公因数 C语言

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

辗转相除法得最大公因数 C语言

首先放出代码

int gcd(int a, int b) 
{
	if(a%b == 0) return b;
	else return gcd(b, a%b);
}

        辗转相除是将a与b相除得到余数k,如果余数k==0则返回值b,如果k不为0则将 除数b 与 k 相除,再判断第二次的余数k2是否为零,如此反复,故为辗转相除。

        其实现原理:

        举个例子,求30与21的最大公因数。假设最大公因数为x,那么30%x == 0, 21%x == 0,

故(30-21)%x == 0(将30拆为 21 与 9, 21 % x == 0, 所以 9 % x == 0)。继续,21中有两个9,21 - 9*2 = 3, 所以 3%x == 0。因为 9%3 == 0 所以3就是最终结果。

        其实就是将一个 较大的数(x的倍数)中若干个 较小的数(依然是x倍数)剔除,剩下的部分依然是 x的倍数,然后一直进行剔除步骤,直到无法继续剔除,最后的值就是我们需要的最大公因数。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/509940.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号