[考前速记] 最大公约数与最大公倍数

最大公约数

cpp 复制代码
int gcd(int a,int b){
    if (b==0)return a;
    else return gcd(b,a%b);
}

熟练了可以写成:

cpp 复制代码
int gcd(int a,int b){
    return b ? gcd(b,a%b):a;
}

值得注意的是:让a和b均为非负数,可以使用algorithm下的abs(int x)和cmath下的fabs(double x);

最大公倍数是在最大公约数的基础上:

最大公倍数等于

cpp 复制代码
a*b/gcd(a,b)

但由于a*b可能溢出,因此可以修改为

cpp 复制代码
a/gcd(a,b)*b;
相关推荐
会周易的程序员7 小时前
多模态AI 基于工业级编译技术的PLC数据结构解析与映射工具
数据结构·c++·人工智能·单例模式·信息可视化·架构
lixzest9 小时前
C++上位机软件开发入门深度学习
开发语言·c++·深度学习
苦藤新鸡10 小时前
4.移动零
c++·算法·力扣
hetao173383710 小时前
2026-01-04~06 hetao1733837 的刷题笔记
c++·笔记·算法
liulilittle11 小时前
XDP VNP虚拟以太网关(章节:一)
linux·服务器·开发语言·网络·c++·通信·xdp
Ralph_Y11 小时前
多重继承与虚继承
开发语言·c++
bkspiderx11 小时前
C++虚析构函数:多态场景下的资源安全保障
c++·析构函数·虚函数表·虚析构函数
White_Can12 小时前
《C++11:列表初始化》
c语言·开发语言·c++·vscode·stl
White_Can12 小时前
《C++11:右值引用与移动语义》
开发语言·c++·stl·c++11
Z1Jxxx12 小时前
字符串翻转
开发语言·c++·算法