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

最大公约数

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;
相关推荐
汉克老师8 分钟前
GESP2024年3月认证C++三级( 第三部分编程题(1、字母求和)
c++·string·gesp三级·gesp3级·大小写判断
沐雪轻挽萤15 分钟前
10. C++17新特性-保证的拷贝消除 (Guaranteed Copy Elision / RVO)
开发语言·c++
leaves falling1 小时前
C/C++ 的内存管理,函数栈帧详讲
java·c语言·c++
wuyoula1 小时前
AI导航智能决策系统源码 附教程
c++·tcp/ip·源码
浅念-1 小时前
从LeetCode入门位运算:常见技巧与实战题目全解析
数据结构·数据库·c++·笔记·算法·leetcode·牛客
XY_墨莲伊3 小时前
【编译原理】实验二:基于有穷自动机FA词法分析器设计与实现
c语言·开发语言·c++·python
小辉同志3 小时前
74. 搜索二维矩阵
c++·leetcode·矩阵·二分查找
fpcc3 小时前
信号处理与AI中的卷积的关系
c++·人工智能·信号处理
t***5444 小时前
能否给出更多现代C++设计模式的示例
开发语言·c++·设计模式
梵尔纳多4 小时前
OpenGL 骨骼动画
c++·图形渲染·opengl