大家好,今天给各位分享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语言求最大公约数代码的内容到此结束了,希望对大家有所帮助。




