求n个数的最大公约数.txt
来自「c语言的一些常见的算法以及思考和改进的文章,写的很不错,花费了很大的精力从网络了」· 文本 代码 · 共 61 行
TXT
61 行
求n个数的最大公约数[原创]
/*
求解n个数的最大公约数,如果这些数的最大公约数为1,则称它们是互素的。
作者:BugEyes
http://BugEyes.blog.edu.cn
*/
#define N 5
#i nclude <conio.h>
int gcd(int array[N])/*方法一*/
{
int result;
int min=array[0];
int i;
for(i=1;i<N;i++)
if(array[i]<min)
min=array[i];
for(result=min;result>=1;result--)
{
for(i=0;i<N&&array[i]%result==0;i++);
if(i>=N)
break;
}
return result;
}
int fun(int m,int n)
{
int i;
i=m>n?n:m;
while(i>=1)
{
if(m%i==0&&n%i==0)
break;
i--;
}
return i;
}
int gcd1(int array[N]) /*方法二*/
{
int i,t;
t=fun(array[0],array[1]);
for(i=2;i<N;i++)
t=fun(t,array[i]);
return t;
}
void main()
{
int array[N]={50,40,20,30,10};
int i,t;
clrscr();
printf("The gcd of the array is:\n%d\n",gcd(array));
printf("The gcd of the array is:\n%d\n",gcd1(array));
}
BugEyes 发表于 2005-9-27 16:07:00
阅读全文(82) | 回复(0)
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?