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

最大公约数

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;
相关推荐
MMjeaty7 分钟前
查找及其算法
c++·算法
yong15858553431 小时前
1. Linux C++ muduo 库学习——库的编译安装
linux·c++·学习
mit6.8242 小时前
回溯剪枝trick
c++
渡我白衣2 小时前
C++世界的混沌边界:undefined_behavior
java·开发语言·c++·人工智能·深度学习·语言模型
却道天凉_好个秋3 小时前
c++ 协程
c++
无敌最俊朗@4 小时前
视频时间基 (time_base) 详解:时间的“刻度单位”
c++
脏脏a5 小时前
【C++ 入门】:引用、内联函数与 C++11 新特性(auto、范围 for、nullptr)全解析
开发语言·c++
AA陈超5 小时前
虚幻引擎5 GAS开发俯视角RPG游戏 P06-28 构建属性菜单小部件控制器
c++·游戏·ue5·游戏引擎·虚幻
恒者走天下5 小时前
cpp / c++零基础就业学习一站式学习平台
开发语言·c++·学习
qq_433554545 小时前
C++ 单调栈
数据结构·c++·算法