如何用C++求两个数的最大公约数和最小公倍数
原理
最大公约数
有两个数字n和m。现在要求两个数字的最大公约数。
例如:n为18,m为4.
正常我们的思路求解最大公约数是暴力破解,遍历一遍公约数,取最大的那个,但是这样有一个问题,就是时间复杂度过高了。
有没有什么优化的方法呢?
我们可以先把18变成18-4=14,然后求和4的最大公约数;以此往复。但是每次都需要递减,碰到1000001和200这样的数字时,时间复杂度还是很高。
所以我们需要有最优化的方法
我们可以把数字递减理解为除以数字很多次,那么就变成了18对4取余,此时变为2和4;然后我们把4对2取余,此时变为2和0;那么最终结果就为2.
最小公倍数
通过观察18和4两个数字,发现18 = 2 * 9; 4 = 2 * 2;9和2都是质数,而2则是共同的最大公约数。
我们假设有两个数字n和m。
n = k * a -- 1式 m = k * b -- 2式 那么gcd(n,m)=k.
所以我们把1式和2式相乘,左边=n * m,右边=k * k * a * b。
就得到n * m = gcd(n, m) * k * a * b
此时的a * b * k 正好式n和m的最小公倍数,所以就得到
n * m = gcd(n, m) * lcm(n, m)
代码
#include <iostream> using namespace std; //定义gcd求最大公约数的函数 int gcd(int num1, int num2) { if (num1 == num2) { return num1; } else if (num1 < num2) { return num1 == 0 ? num2 : gcd(num1, num2 % num1); } else { return gcd(num2, num1); } } // 定义最小公倍数的函数 int lcm(int num1, int num2) { return num1 / gcd(num1, num2) * num2; } int main() { int n, m; cout << "输入两个数字n和m:\n"; cin >> n >> m; printf("%d和%d的最大公约数为%d \n", n, m, gcd(n, m)); printf("%d和%d的最小公倍数为%d", n, m, lcm(n, m)); return 0; }
运行结果
补充:性质
1.最小公倍数是最大公因数的倍数(最小公倍数 / 最大公因数 = 一个整数)
2.a与b的和差是最大公因数的倍数
3.最大公因数一定小于或等于min(a,b)
4.最小公倍数一定大于或等于max(a,b)
5.a*b = 最小公倍数*最大公因数
6.如果a, b两个数是互质数,最大公因数等于1,最小公倍数等于a*b
总结
到此这篇关于如何用C++求两个数的最大公约数和最小公倍数的文章就介绍到这了,更多相关C++求最大公约数和最小公倍数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
C语言的fork函数在Linux中的进程操作及相关面试题讲解
fork函数只能在类Unix的系统中使用,用于创建子线程,这里总结了C语言的fork函数在Linux中的进程操作及相关面试题讲解,先来看一下C语言程序的存储空间与进程示意:2016-06-06简述C语言中system()函数与vfork()函数的使用方法
这篇文章主要介绍了简述C语言中system()函数与vfork()函数的使用方法,是C语言入门学习中的基础知识,需要的朋友可以参考下2015-08-08
最新评论