求两个数的最大公约数(编程之美上有解答)

这里所使用的其实就是阿基里德算法,求两个数的最大公约数。

算法过程: 比如求 17与6的最大公约数

令M=17,N=6;

第一次:R=M%N=5;  M=N=6; N =R=5

第二次:  R=M%N = 1; M=N=5;  N=R=1;

第三次: R=M%N =0, M=N=1,N=R=0。

所以结束条件为if(N==0)

返回                     return M

 

/*
求两个数的最大公约数
*/

#include<stdio.h>
#include<time.h>
#include<stdlib.h>

void init_num(long int *x,long int *y)
{
 int i;
 srand( (unsigned)time( NULL ) );
 for(i=0;i<65536;i++)
 {
  srand( (unsigned)time( NULL ) );
  x[i]=rand();
  srand( (unsigned)time( NULL ) );
  y[i]=rand();
 }
}
long int gcd_one(long int x,long int y)
{
 if(y==0)
  return x;
 else
  return gcd_one(y,x%y);
}

long int gcd_two(long int x,long int y)
{
 if(y==0)
  return x;
 else if(x<y)
  return gcd_two(y,x);

 else
  return gcd_two(y,x-y);

}


int  IsEven(long int x)  /*是偶数的话返回1*/
{
 if(x&1)
  return 0;
 else
  return 1;
}
long int gcd_three(long int x, long int y)
{
 if(y==0)
  return x;
 else if(x<y)
  return gcd_three(y,x);
 else
 {
  if(IsEven(x))
  {
   if(IsEven(y))
   {
    return (gcd_three(x>>1, y>>1) )<<1;
   }
   else
   {
    return (gcd_three(x>>1,y) );
   }
  }

  else
  {
   if(IsEven(y) )
   {
    return (gcd_three(x,y>>1) );
   }
   else
   {
    return (gcd_three(y,x-y) );
   }
  }
 }
}

 


int main()
{
 clock_t start,finish;
 double difTime;
 int x[65536];
 int y[65536];
 int i;
 init_num(x,y);

 start=clock();
 for(i=0;i<65536;i++)
 {
  gcd_two(x[i],y[i]);
 }

 printf("gcd  is %ld/n",gcd_one(x[100],y[100]));
 printf("gcd  is %ld/n",gcd_two(x[100],y[100]));
 printf("gcd  is %ld/n",gcd_three(x[100],y[100]));

 finish=clock();
 difTime=(double)(finish-start)/CLOCKS_PER_SEC;
 printf("use %f secons/n",difTime);

 
 return 0;
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值