求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)
来源:互联网 发布:爱淘宝现金红包 编辑:程序博客网 时间:2024/05/18 20:47
#include <iostream>#include <cmath>using namespace std;//两个数的最大公约数--欧几里得算法int gcd(int a, int b){ if (a < b) swap(a, b); if (b == 0) return a; else return gcd(b, a%b);}//n个数的最大公约数算法//说明: //把n个数保存为一个数组//参数为数组的指针和数组的大小(需要计算的数的个数)//然后先求出gcd(a[0],a[1]), 然后将所求的gcd与数组的下一个元素作为gcd的参数继续求gcd//这样就产生一个递归的求ngcd的算法int ngcd(int *a, int n){ if (n == 1) return *a; return gcd(a[n-1], ngcd(a, n-1));}//两个数的最小公倍数(lcm)算法//lcm(a, b) = a*b/gcd(a, b)int lcm(int a, int b){ return a*b/gcd(a, b);}//n个数的最小公倍数算法//算法过程和n个数的最大公约数求法类似//求出头两个的最小公倍数,再将欺和大三个数求最小公倍数直到数组末尾//这样产生一个递归的求nlcm的算法int nlcm(int *a, int n){ if (n == 1) return *a; else return lcm(a[n-1], nlcm(a, n-1));}void main(){ int *a = new int[3]; a[0] = 3; a[1] = 4; a[2] = 5; cout << ngcd(a, 3) << endl;}
0 0
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)的较优算法
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)
- 求两个或N个数的最大公约数和最小公倍数
- 152 求两个或 N 个数的最大公约数和最小公倍数
- 求两个或N个数的最大公约数(gcd)和…
- 求两个数或者N个数的最大公约数和最小公倍数
- 求任意两个正整数的最大公约数和(GCD)和最小公倍数(LCM)
- java-求任意两个正整数的最大公约数和(GCD)和最小公倍数(LCM)
- 求最大公约数(gcd)和最小公倍数(lcm)算法
- GCD&LCM-求最大公约数&最小公倍数
- 求N个数的最小公倍数(LCM)
- 最小公倍数(LCM)和最大公约数(GCD)
- 最大公约数gcd和最小公倍数lcm
- Eclipse快捷键大全(转载)
- 结构体结合qsort排序
- poj 1003
- 火狐设置User Agent
- hdu1500
- 求两个或N个数的最大公约数(gcd)和最小公倍数(lcm)
- Spring MVC Thymeleaf
- 零基础unity3d游戏开发系列目录
- 约瑟夫环
- 查看证书 certmgr.msc
- BIEE用户使用代理账号身份访问Analytics页面
- 使用其他机器上的硬盘启动Centos5系统panic问题解决方法
- OSI七层参考模型每一层都有哪些协议
- android ImageView scaleType属性