求最大公约数
来源:互联网 发布:域名是什么样子 编辑:程序博客网 时间:2024/05/29 17:30
求两个不全为0的非负整数m和n的最大公约数,记为gcd(m,n).要求:
分别使用欧几里德算法、连续整数检测算法、公因数算法实现;
欧几里德算法:重复应用下列等式,直到 m mod n=0.
gcd(m,n)=gcd(n, m mod n)
用于计算gcd(m,n)的欧几里德算法
①如果n=0,返回m的值作为结果,同时过程结束;否则,进入下一步;
②m除以n,将余数赋值给r;
③将n的值赋给m,将r的值赋给n,返回第一步。
#include<iostream>using namespace std;//欧几里得算法int gcd(int m, int n){int r;while (n!=0){r = m%n;m = n;n = r;}return m;}int main(){int a, b;cout << "请输入两个非负整数:" << endl;cin >> a >> b;cout << "两数的最大公约数为:" << gcd(a, b) << endl;return 0;}
用于计算gcd(m,n)的连续整数检测算法
①将min{m,n}的值赋给t;
②m除以t,如果余数为0,进入下一步,否则,进入第四步;
③n除以t,如果余数为0,返回t的值作为结果,否则进入第四步;
④把t的值减1,返回第二步。
int gcd(int m, int n){int t;if (m > n) t = n;else t = m;while (t){if (m%t == 0 && n%t == 0)break;else t = t - 1;}return t;}
公因数算法:
①找到m的所有质因数;
②找到n的所有质因数;
③从第一步和第二步求得的质因数分解式中找出所有的公因数;
④将第三步中找到的质因数相乘,其结果作为给定数字的最大公约数。
int gcd(int m, int n){vector<int> v1, v2, v3;int m2 = m, n2 = n, d = 1;for (int i = 1; i <= m; i++) //求m的所有质因数,放在v1{if (m%i==0){m2 = m / i;v1.push_back(m2);}}for (int i = 1; i <= n; i++) //求n的所有质因数,放在v2{if (n%i==0){n2 = n / i;v2.push_back(n2);}}for (int x = 0; x < v1.size(); x++) //找出相同的质因数{for (int y = 0; y < v2.size(); y++){if (v1[x] == v2[y]){v3.push_back(v1[x]);}}}for (int i = 0; i < v3.size(); i++) //找到的质因数相乘{d =d * v3[i];}return d;}
1 0
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 求最大公约数
- 图形学之深度缓存简介
- WAV 文件格式分析
- Java四种代码块及运行优先级
- Linux静态库的使用
- 病毒侵袭 HDU
- 求最大公约数
- Hibernate 一级缓存的细节
- C++11——移动语义
- Liner_Shaker_Full
- 递归实例总结
- 内存泄漏及管理(01)-简述GC机制和检测工具
- MySQL数据库最基本的操作
- 实现一个简单的进度条
- windows下用navicat远程链接虚拟机Linux下MySQL数据库