淡水求咸

博客园已经停止更新,请移步 http://lovecjh.com/

导航

常用两个算法

1.求两整数的最大公约数:

int mcd(unsigned int a,unsigned int b)
{
if(b==0)
{
return a;
}
return mcd(b,a%b);
}

  对上述解法,出现a%b取模运算对于大数来说效率很低,针对这个方法的改进见《编程之美》2.7节最大公约数问题。

 

2.判断一个整数是否为素数:

bool IsPrime(uint x)
{
for(uint i=2;i<=x/2;i++)
{
if(x%i==0)
{
return false;
}
}
return true;
}

 

posted on 2011-12-22 16:06  深圳彦祖  阅读(281)  评论(1编辑  收藏  举报