c语言求最大公约数(c语言求最大公约数代码)

大家好,今天给各位分享c语言求最大公约数的一些知识,其中也会对c语言求最大公约数代码进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!

在编程的世界里,算法是基石,而算法中的经典之一就是求最大公约数(GCD)。今天,我们就来聊聊如何用C语言实现这个算法,从入门到精通,一步步揭开GCD的神秘面纱。

一、什么是最大公约数?

让我们来了解一下什么是最大公约数。简单来说,两个或多个整数共有的约数中最大的一个就是它们的最大公约数。例如,12和18的最大公约数是6。

二、为什么需要求最大公约数?

求最大公约数在数学、计算机科学等领域都有广泛的应用。比如,在密码学中,最大公约数可以用来破解密钥;在计算机图形学中,最大公约数可以用来优化图像处理算法。

三、C语言求最大公约数的基本思路

在C语言中,求最大公约数的基本思路是:通过辗转相除法(也称欧几里得算法)来计算。辗转相除法的基本思想是:用较大数除以较小数,再用除数除以上一次的余数,如此循环,直到余数为0,此时的除数即为最大公约数。

四、C语言实现最大公约数

下面,我们就用C语言来实现最大公约数。

“`c

include

// 函数声明

int gcd(int a, int b);

int main() {

int num1, num2, result;

// 用户输入两个整数

printf(“

c语言求最大公约数

求差判定法.

如果两个数相差不大,可以用大数减去小数,所得的差与小数的最大公约数就是原来两个数的最大公约数.例如:求78和60的最大公约数.78-60=18,18和60的最大公约数是6,所以78和60的最大公约数是6.

如果两个数相差较大,可以用大数减去小数的若干倍,一直减到差比小数小为止,差和小数的最大公约数就是原来两数的最大公约数.例如:求92和16的最大公约数.92-16=76,76-16=60,60-16=44,44-16=28,28-16=12,12和16的最大公约数是4,所以92和16的最大公约数就是4.

辗转相除法.

当两个数都较大时,采用辗转相除法比较方便.其方法是:

以小数除大数,如果能整除,那么小数就是所求的最大公约数.否则就用余数来除刚才的除数;再用这新除法的余数去除刚才的余数.依此类推,直到一个除法能够整除,这时作为除数的数就是所求的最大公约数.

例如:求4453和5767的最大公约数时,可作如下除法.

5767÷4453=1余1314

4453÷1314=3余511

1314÷511=2余292

511÷292=1余219

292÷219=1余73

219÷73=3

于是得知,5767和4453的最大公约数是73.

辗转相除法适用比较广,比短除法要好得多,它能保证求出任意两个数的最大公约数.

——————————————————————————–

小学数学温习过后,先来个两个数递归版的

int GetGCDRec(int n, int m)

{

if(m< n)

{

m ^= n;

n ^= m;

m ^= n;

}

if(n== 0)

return m;

else

return GetGCDRec(n, m% n);

}

辗转相除法,求一个数组中所有数的最大公约数

int GetGCD(int*arr, int len)

{

int iMax= arr[0], iCurr, iRemainder;

for(int i= 1; i< len; i++)

{

iCurr= arr[i];

if(iMax< iCurr)

{

iMax ^= iCurr;

iCurr ^= iMax;

iMax ^= iCurr;

}

iRemainder= iMax% iCurr;

while(iRemainder)

{

iMax= iCurr;

iCurr= iRemainder;

iRemainder= iMax% iCurr;

}

iMax= iCurr;

}//for

return iMax;

}

最小公倍数就是乘积除以最大公约数

int GetLCM(int*arr, int len)

{

int multiple= 1;

for(int i= 0; i< len; i++)

multiple*= arr[i];

return multiple/ GetGCD(arr, len);

}

用C语言求最大公约数。

1、新建一个C语言源程序,这里使用Visual C++6.0的软件:

2、从键盘中输入两个正整数a和b。取两个数a,b中的较小值存放到变量n中。从两个数a和b中的较小数开始逐个减小1,寻找能整除a和b的整数,第一个找到的整数即整数a和b的最大公约数,最后将找到的结果输出即可完成程序的编写:

3、对源程序编译运行,测试输入4、6,得到最大公约数2说明程序是正确的,以上就是用c语言求最大公约数的过程:

怎么用c语言编程求最大公约数

求差判定法.

如果两个数相差不大,可以用大数减去小数,所得的差与小数的最大公约数就是原来两个数的最大公约数.例如:求78和60的最大公约数.78-60=18,18和60的最大公约数是6,所以78和60的最大公约数是6.

如果两个数相差较大,可以用大数减去小数的若干倍,一直减到差比小数小为止,差和小数的最大公约数就是原来两数的最大公约数.例如:求92和16的最大公约数.92-16=76,76-16=60,60-16=44,44-16=28,28-16=12,12和16的最大公约数是4,所以92和16的最大公约数就是4.

辗转相除法.

当两个数都较大时,采用辗转相除法比较方便.其方法是:

以小数除大数,如果能整除,那么小数就是所求的最大公约数.否则就用余数来除刚才的除数;再用这新除法的余数去除刚才的余数.依此类推,直到一个除法能够整除,这时作为除数的数就是所求的最大公约数.

例如:求4453和5767的最大公约数时,可作如下除法.

5767÷4453=1余1314

4453÷1314=3余511

1314÷511=2余292

511÷292=1余219

292÷219=1余73

219÷73=3

于是得知,5767和4453的最大公约数是73.

辗转相除法适用比较广,比短除法要好得多,它能保证求出任意两个数的最大公约数.

——————————————————————————–

小学数学温习过后,先来个两个数递归版的

int GetGCDRec(int n, int m)

{

if(m< n)

{

m ^= n;

n ^= m;

m ^= n;

}

if(n== 0)

return m;

else

return GetGCDRec(n, m% n);

}

辗转相除法,求一个数组中所有数的最大公约数

int GetGCD(int*arr, int len)

{

int iMax= arr[0], iCurr, iRemainder;

for(int i= 1; i< len; i++)

{

iCurr= arr[i];

if(iMax< iCurr)

{

iMax ^= iCurr;

iCurr ^= iMax;

iMax ^= iCurr;

}

iRemainder= iMax% iCurr;

while(iRemainder)

{

iMax= iCurr;

iCurr= iRemainder;

iRemainder= iMax% iCurr;

}

iMax= iCurr;

}//for

return iMax;

}

最小公倍数就是乘积除以最大公约数

int GetLCM(int*arr, int len)

{

int multiple= 1;

for(int i= 0; i< len; i++)

multiple*= arr[i];

return multiple/ GetGCD(arr, len);

}

OK,关于c语言求最大公约数和c语言求最大公约数代码的内容到此结束了,希望对大家有所帮助。

© 版权声明
THE END
喜欢就支持一下吧
点赞8 分享