Chinaunix首页 | 论坛 | 博客
  • 博客访问: 332448
  • 博文数量: 69
  • 博客积分: 2090
  • 博客等级: 大尉
  • 技术积分: 708
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-23 09:31
文章分类

全部博文(69)

文章存档

2012年(1)

2011年(4)

2010年(48)

2009年(14)

2008年(2)

我的朋友

分类: C/C++

2010-07-31 18:04:01

辗转相除法的理论基础:欧几里德算法。
定理:gcd(a,b) = gcd(b,a mod b)  前提:a > b 

证明:
a可以表示成 a = kb + r,则r = a % b 
假设d是a,b的一个公约数,则有 
a  % d =0, b % d = 0,而r = a - kb,因此 r % d  = (a - kb)  % d  = 0
因此d是(b, a % b)的公约数,
即a 和 b的公约数也是a对b求模的结果的公约数 

假设d 是(b,a % b)的公约数,则 
b % d  = 0, r % d = 0,但是a = kb +r 
因此 a % d  = (kb +r ) % d = 0 
因此d也是(a,b)的公约数 

下面是用辗转相除法求最大公约数的递归和非递归方法:
#include

//辗转相除求最大公约数 递归方法

int fun(int x,int y)
{
int r = 0;
if(x < y) fun(y,x);
else if(y == 0) return x;
else
{
r = x % y;
return fun(y,r);
}
}


//辗转相除求最大公约数,非递归方法

int fun1(int x,int y)
{
int r;
if (x < y)
{
x = x + y;
y = x - y;
x = x - y;
}

do
{
r = x % y;
x = y;
y = r;
}while (r != 0);
return x;
}


阅读(3155) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~