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

最大公约数

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;
相关推荐
桦01 小时前
【C++复习】:继承
开发语言·c++
鱼难终2 小时前
类和对象(下)
c++
云泽8082 小时前
深入 AVL 树:原理剖析、旋转算法与性能评估
数据结构·c++·算法
邪神与厨二病3 小时前
Problem L. ZZUPC
c++·数学·算法·前缀和
elseif1234 小时前
出题团招人【ETOI_】
c++
第二只羽毛5 小时前
C++ 高并发内存池1
大数据·开发语言·c++·开源
不想看见4045 小时前
C++/Qt 实习岗位深度解析【结合一次研发实习谈感受】
开发语言·c++·qt
王老师青少年编程5 小时前
信奥赛C++提高组csp-s之组合数学专题课:鸽巢原理详解及案例实践
c++·组合数学·信奥赛·抽屉原理·csp-s·提高组·鸽巢原理
njidf5 小时前
C++与Qt图形开发
开发语言·c++·算法
qwehjk20086 小时前
代码动态生成技术
开发语言·c++·算法