寻找最小公倍数高效算法

理论基础

理论一:

  • 两个数的最小公倍数等于这两个数的乘积除以它们的最大公约数(GCD)。
  • 即 LCM(a, b) = |a*b| / GCD(a, b)

例如,求12和18的最小公倍数:

  • GCD(12, 18) = 6
  • LCM(12, 18) = |12*18| / 6 = 216 / 6 = 36
    理论二:

辗转相除法,也称为欧几里得算法,是一种用于寻找两个整数最大公约数的高效算法。

假设我们想要找到81和153的最大公约数。

  1. 153除以81,商为1,余数为72。
  2. 然后用81除以72,商为1,余数为9。
  3. 再用72除以9,商为8,余数为0。

这时余数为0,所以在上一步中,9就是153和81的最大公约数。

cpp 复制代码
//C++代码实现
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;

int getGCD(int did, int div) {	//辗转相除法
	while(did % div) {
		int red = did % div;
		did = div;
		div = red;
	}
	return div;
}

int main(int argc, char** argv) {
	srand(time(0));
	int res1 = rand()%1001;
	int res2 = rand()%801;
	
	int gcd = getGCD(res1, res2);
	cout<<"The GCD is "<<gcd<<endl;
	
	int lcm = res1 * res2 / gcd;
	cout<<"The LCM of "<<res1<<" and "<<res2<<" is "<<lcm;
	return 0;
}
相关推荐
CoovallyAIHub5 分钟前
全球OCR新标杆!百度0.9B小模型斩获四项SOTA,读懂复杂文档像人一样自然
深度学习·算法·计算机视觉
weixin_377634848 分钟前
【强化学习】RLMT强制 CoT提升训练效果
人工智能·算法·机器学习
拾光Ծ33 分钟前
【C++高阶数据结构】红黑树
数据结构·算法
Qiuner41 分钟前
《掰开揉碎讲编程-长篇》重生之哈希表易如放掌
数据结构·算法·leetcode·力扣·哈希算法·哈希·一文读懂
cici158741 小时前
基于MATLAB的ADS-B接收机卫星与接收天线初始化实现
算法·matlab
木井巳1 小时前
[Java数据结构与算法]详解排序算法
java·数据结构·算法·排序算法
美狐美颜SDK开放平台2 小时前
直播美颜SDK功能开发实录:自然妆感算法、人脸跟踪与AI美颜技术
人工智能·深度学习·算法·美颜sdk·直播美颜sdk·美颜api
缓风浪起2 小时前
【力扣】2011. 执行操作后的变量值
算法·leetcode·职场和发展
gsfl3 小时前
双指针算法
算法·双指针
郝学胜-神的一滴3 小时前
矩阵的奇异值分解(SVD)及其在计算机图形学中的应用
程序人生·线性代数·算法·矩阵·图形渲染