【编程之美】求最大公约数
2015-11-21 11:27
357 查看
//解法一:更相减损法
BigInt(BigInt x,BigInt y){
if(x < y){
return gcd(y,x);
}
if(y==0) return x;
else return gcd(x-y,y);//gcd(y-x,y)
}
//解法二:辗转相除法
int gcd(int x, int y){
return !b ? a:gcd(b,a%b);
}
//解法三:解法一和解法二的集合
BigInt gcd(BigInt x,BigInt y){
if(x < y) return gcd(y,x);
if(y==0) return x;
else{
if(IsEven(x)){
if(IsEven(y)) return 2*gcd(x>>1,y>>1);
else return gcd(x>>1,y);
}
else{
if(IsEven(y)) return gcd(x,y>>1);
else return gcd(y,x-y);
}
}
}
BigInt(BigInt x,BigInt y){
if(x < y){
return gcd(y,x);
}
if(y==0) return x;
else return gcd(x-y,y);//gcd(y-x,y)
}
//解法二:辗转相除法
int gcd(int x, int y){
return !b ? a:gcd(b,a%b);
}
//解法三:解法一和解法二的集合
BigInt gcd(BigInt x,BigInt y){
if(x < y) return gcd(y,x);
if(y==0) return x;
else{
if(IsEven(x)){
if(IsEven(y)) return 2*gcd(x>>1,y>>1);
else return gcd(x>>1,y);
}
else{
if(IsEven(y)) return gcd(x,y>>1);
else return gcd(y,x-y);
}
}
}
相关文章推荐
- Linux C函数参考手册(PDF版)
- Lua教程(十七):C API简介
- C#实现打造气泡屏幕保护效果
- 使用C#代码获取存储过程返回值
- C/C++数据对齐详细解析
- 利用C语言来求最大连续子序列乘积的方法
- 字符串的组合算法问题的C语言实现攻略
- C 语言基础教程(我的C之旅开始了)[三]
- C++中的extern “C”用法详解
- C 语言基础教程(我的C之旅开始了)[七]
- 最大子矩阵问题实例解析
- C字符串操作函数实现方法小结
- C语言中static的作用及C语言中使用静态函数有何好处
- 字典树的基本知识及使用C语言的相关实现
- 详解C语言中free()函数与getpagesize()函数的使用
- C/C++ 宏详细解析
- 使用C语言解决字符串全排列问题
- C/C++实现对STORM运行信息查看及控制的方法
- 用C#生成不重复的随机数的代码