首页技术c语言求最大公约数?最大公约数和最小公倍数c语言

c语言求最大公约数?最大公约数和最小公倍数c语言

编程之家2026-05-23662次浏览

其实c语言求最大公约数的问题并不复杂,但是又很多的朋友都不太了解最大公约数和最小公倍数c语言,因此呢,今天小编就来为大家分享c语言求最大公约数的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!

c语言求最大公约数?最大公约数和最小公倍数c语言

用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.

c语言求最大公约数?最大公约数和最小公倍数c语言

辗转相除法.

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

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

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

5767÷4453=1余1314

4453÷1314=3余511

c语言求最大公约数?最大公约数和最小公倍数c语言

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语言程序设计如何求最大公约数

具体操作步骤如下:

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

二、从键盘中输入两个正整数a和b。代码:printf("please input two number:

");int a,b;scanf("%d%d",&a,&b)。

三、取两个数a,b中的较小值存放到变量n中。代码:int n=a;if(n>b)n=b。

四、从两个数a和b中的较小数开始逐个减小1,寻找能整除a和b的整数。第一个找到的整数即整数a和b的最大公约数。

五、点击工具栏的如图图标,对源程序编译运行。

六、测试输入4,6,得到最大公约数2。程序是正确的,以测试更多的数。

七、

上面面步骤是编程的思路,给出完整代码,方便复制使用。#include<stdio.h>void main(){printf("please input two number:

"); int a,b;;scanf("%d%d",&a,&b);//从键盘输入两个数 int n=a;;f(n>b) n=b;//取两个数中的较小数 for(int i=n;i>=1;i--){ if(a%i==0&&b%i==0){ printf("最大公约数:%d

",i); break;}}}。

关于c语言求最大公约数到此分享完毕,希望能帮助到您。

手机php文件转txt,php读取本地txt文件ai绘画免费 ai绘画软件免费的有哪些