介绍最大公因数和最小公约数(C++)

最大公因数(GCD)与最小公倍数(LCM)的概念

最大公因数(Greatest Common Divisor,GCD)指两个或多个整数共有的最大正整数因数。最小公倍数(Least Common Multiple,LCM)则是能够被这些整数整除的最小正整数。两者关系为:

\\text{LCM}(a, b) = \\frac{\|a \\times b\|}{\\text{GCD}(a, b)}


C++ 实现方法

欧几里得算法(递归法)计算 GCD

通过递归方式求解,基于数学原理:

\\text{GCD}(a, b) = \\text{GCD}(b, a % b) 代码示例:

cpp 复制代码
int gcd(int a, int b) {
    if (b == 0) return a;
    return gcd(b, a % b);
}
迭代法计算 GCD

避免递归开销的迭代实现:

cpp 复制代码
int gcd(int a, int b) {
    while (b != 0) {
        int temp = b;
        b = a % b;
        a = temp;
    }
    return a;
}
计算 LCM

利用 GCD 结果推导 LCM:

cpp 复制代码
int lcm(int a, int b) {
    return abs(a * b) / gcd(a, b);
}

标准库函数

C++17 起可直接使用 <numeric> 中的 std::gcdstd::lcm

cpp 复制代码
#include <numeric>
int gcd_val = std::gcd(a, b);
int lcm_val = std::lcm(a, b);

注意事项

  • 输入为负数时,需转换为绝对值处理或依赖库函数自动处理。
  • 大整数运算时需考虑使用 long long 类型避免溢出。
相关推荐
摇滚侠4 分钟前
SpringMVC 入门到实战 文件上传 75-77
java·后端·spring·maven·intellij-idea
GIS数据转换器11 分钟前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机
ct97824 分钟前
React 状态管理方案深度对比
开发语言·前端·react
ao-weilai42 分钟前
C++:哈希表
c++·哈希算法·散列表
数量技术宅42 分钟前
2026量化前沿:从Reddit热帖到Python实战,如何用赫斯特指数(Hurst)狙击虚假突破?
开发语言·python
汉克老师1 小时前
GESP7级C++考试语法知识(二、指数函数(1、pow() 函数)
c++·指数函数·pow·gesp7级·精度误差
华如锦1 小时前
面了很多 Java转AI Agent方向,一些面试题总结
java·开发语言·人工智能·python·ai
睡不醒男孩0308231 小时前
CLup 6.x 版本中针对StarRocks 存算一体集群的完整操作手册
java·服务器·网络·clup
huangdong_1 小时前
电商商品SKU图自动分类技术实现:从DOM解析到智能归档
开发语言
dog2501 小时前
网络长尾延时的重尾本质
开发语言·网络·php