求最大公约数
2014-05-27 14:28
127 查看
//求最大公约数
//利用欧几里得算法(也叫辗转相除法)
#include "stdafx.h"
//递归程序
unsigned int GcdRecursively (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return x+y;//return非0值
return GcdRecursively(y,x%y);
}
//循环程序
unsigned int GcdIteratively (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return 0;
unsigned int temp = x % y;
while (temp)
{
x = y;
y = temp;
temp = x % y;
}
return y;
}
int _tmain(int argc, _TCHAR* argv[])
{
unsigned int x = 90;
unsigned int y = 60;
unsigned int gcd = GcdRecursively(x,y);
gcd = GcdIteratively(x,y);
return 0;
}
但是循环程序不够简洁,有重复的部分。这样写更好:
unsigned int GcdIteratively2 (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return 0;
unsigned int remain = 0;
while (y)
{
remain = x % y;
x = y;
y = remain;
}
return x;
}
//利用欧几里得算法(也叫辗转相除法)
#include "stdafx.h"
//递归程序
unsigned int GcdRecursively (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return x+y;//return非0值
return GcdRecursively(y,x%y);
}
//循环程序
unsigned int GcdIteratively (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return 0;
unsigned int temp = x % y;
while (temp)
{
x = y;
y = temp;
temp = x % y;
}
return y;
}
int _tmain(int argc, _TCHAR* argv[])
{
unsigned int x = 90;
unsigned int y = 60;
unsigned int gcd = GcdRecursively(x,y);
gcd = GcdIteratively(x,y);
return 0;
}
但是循环程序不够简洁,有重复的部分。这样写更好:
unsigned int GcdIteratively2 (unsigned int x, unsigned int y)
{
if (x == 0 || y == 0)
return 0;
unsigned int remain = 0;
while (y)
{
remain = x % y;
x = y;
y = remain;
}
return x;
}
相关文章推荐
- C++实现求解最大公约数和最小公倍数
- CommDivisorInArry数组最大公约数
- 51nod 1179 最大的最大公约数
- [置顶] 1179 最大的最大公约数
- 第11周项目2 求最大公约数1
- 常见算法:C语言求最小公倍数和最大公约数三种算法
- [置顶] 【C语言】求两个数的最大公约数
- 第十一周---求两个数的最大公约数
- 第十一周项目二 求最大公约数
- 第十一周项目二(1)最大公约数
- 编写C语言程序求两个数的最大公约数
- 编程计算两个数的最大公约数
- 第十一周 项目二 求两个数的最大公约数
- 51nod 1011 最大公约数GCD
- 九度 1056 最大公约数
- C++实验七—最大公约数与最小公倍数
- 第十二周项目三—求最大公约数
- c++实验7--最大公约数与最小公倍数
- 浅析求两个数的最大公约数的三种算法
- c++实验7-最大公约数与最小公倍数