求两个或N个数的最大公约数(gcd)和…
来源:互联网 发布:it专业课程 编辑:程序博客网 时间:2024/06/05 16:40
感谢作者
原文:http://www.cppblog.com/linqiu/archive/2007/08/01/29145.html
#include <iostream>#include <cmath>using namespace std;int gcd(int a, int b);int ngcd(int *a, int n);int lcm(int a, int b);int nlcm(int *a, int n);int main(){ //int a,b; //cin >> a >> b; //cout << lcm(a, b) << endl; int *a = new int[3]; a[0] = 3; a[1] = 4; a[2] = 5; cout << nlcm(a, 3) << endl; return 0;}//两个数的最大公约数--欧几里得算法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));}
1 0
- 求两个或N个数的最大公约数(gcd)和…
- 求两个或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个数的最大公约数和最小公倍数
- 【ZOJ】4846 GCD Reduce(求n个数的最大公约数)
- 程序员面试题精选(47):两个或N个数的最大公约数和最小公倍数的求解
- 求N个数的最大公约数
- 求两个正整数的最大公约数(GCD)
- 求两个自然数的最大公约数(GCD)?
- 求两个正整数的最大公约数GCD
- 求两个数m,n的最大公约数和最小公倍数
- Java实现的Sequence工具 - 1
- Java实现的Sequence工具 - 2
- SqlHelper类
- Zookeeper的配置
- 数论之因子个数的求法
- 求两个或N个数的最大公约数(gcd)和…
- CodeForces 158C.Cd and pwd command
- struct学习
- Spreadsheet 常用属性
- CS与BS区别
- 怎样在easyUi里面获取到easyui-tree
- Jquery 基础
- CSDN密码又被改了
- 杨辉三角