C++ 怎么求最小公倍数 C++ gcd辅助计算lcm代码【逻辑】
发布时间 - 2026-01-29 00:00:00 点击率:次C++17起可用std::gcd配合lcm(a,b)=abs(a*b)/gcd(a,b)求最小公倍数,但需防溢出(建议先除gcd再乘)、处理0(std::gcd(0,0)为0致除零)、用迭代版gcd更安全,多参数需链式调用lcm(lcm(a,b),c),并确保编译器支持C++17。
用 std::gcd 直接算 lcm 最省事
C++17 起标准库就提供了 std::gcd,配合公式 lcm(a, b) = abs(a * b) / gcd(a, b) 就能安全求最小公倍数。但注意:直接写 a * b 容易溢出,尤其 int 类型两个大数相乘就崩了。
实操建议:
- 先转成
long long再做乘法,或者用static_cast(a) * b - 除法前先除以
gcd降低中间值——比如写成abs(a / gcd(a, b)) * abs(b)(前提是a能被gcd整除,而它确实可以) - 别忘了处理零:任意数和 0 的
lcm按数学定义是 0,但std::gcd(0, 0)返回 0,会导致除零错误,必须单独判断
自己实现 gcd 时为什么推荐欧几里得迭代版
递归版 gcd 简洁但有栈溢出风险(比如 gcd(INT_MAX, 1) 会递归上百万次),而迭代版没这问题,也更易内联、编译器优化友好。
典型写法:
立即学习“C++免费学习笔记(深入)”;
int gcd(int a, int b) {
a = abs(a); b = abs(b);
while (b != 0) {
int r = a % b;
a = b;
b = r;

}
return a;
}注意点:
- 务必取绝对值,否则负数取模行为在 C++ 中依赖实现(
-5 % 3可能是 -2 或 1) - 用
while循环比do-while更稳妥,避免b == 0时跳过首循环导致返回错误值 - 如果参数可能是
long long,函数签名要同步改,别让int截断
lcm 函数不支持多个数?得自己叠调用
标准库没有 std::lcm 多参数重载(C++17 只有双参数),想求三个数的最小公倍数,不能直接 lcm(a, b, c)。
正确做法是链式调用:
-
lcm(lcm(a, b), c)—— 这是通用且可读性最好的方式 - 如果是一组数(如
vector),用std::accumulate配合二元lcm函数 - 别写成
lcm(a, lcm(b, c)),虽然数学等价,但顺序影响中间结果大小,可能加剧溢出风险(例如b和c的lcm已很大,再跟a算就爆了)
用 std::lcm(C++17)却报错?检查编译器和头文件
即使写了 #include ,仍编译失败,大概率是编译器没开 C++17 或版本太老。
验证和修复步骤:
- 确认编译选项:g++/clang++ 加
-std=c++17或更高;MSVC 用/std:c++17 - Clang 7 以下、GCC 8 以下、MSVC 2017 15.7 以前都不支持
std::lcm,得自己写 -
std::lcm要求参数同类型且为整型,传double或混合int/long会编译失败 - 它内部已处理了 0 和溢出(抛
std::overflow_error),但你得try/catch或查文档确认行为
最常被忽略的是:两个大质数的 lcm 就是它们乘积,哪怕单个数在 int 范围内,乘积也极易越界——所以别只测小样例,得用接近 INT_MAX 的数压一压。
# 栈
# c++
# 质数
# overflow
# 标准库
# 为什么
# while
# include
# try
# catch
# 整型
# 递归
# int
# double
# 循环
# 链式
# 迭代
# 的是
# 欧几里得
# 这是
# 都不
# 最好的
# 就能
# 多个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
VIVO手机上del键无效OnKeyListener不响应的原因及解决方法
如何用已有域名快速搭建网站?
如何在云指建站中生成FTP站点?
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
如何用y主机助手快速搭建网站?
如何基于云服务器快速搭建个人网站?
如何制作一个表白网站视频,关于勇敢表白的小标题?
Laravel如何优化应用性能?(缓存和优化命令)
大型企业网站制作流程,做网站需要注册公司吗?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
浅析上传头像示例及其注意事项
如何用IIS7快速搭建并优化网站站点?
原生JS实现图片轮播切换效果
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
如何用美橙互联一键搭建多站合一网站?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
怎么用AI帮你为初创公司进行市场定位分析?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
如何有效防御Web建站篡改攻击?
Laravel如何生成API文档?(Swagger/OpenAPI教程)
如何快速生成ASP一键建站模板并优化安全性?
个人摄影网站制作流程,摄影爱好者都去什么网站?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
非常酷的网站设计制作软件,酷培ai教育官方网站?
制作电商网页,电商供应链怎么做?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】
如何在云服务器上快速搭建个人网站?
青岛网站建设如何选择本地服务器?
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
简单实现Android验证码
Python3.6正式版新特性预览
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
Bootstrap整体框架之JavaScript插件架构
EditPlus中的正则表达式实战(6)
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
如何解决hover在ie6中的兼容性问题
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
西安专业网站制作公司有哪些,陕西省建行官方网站?
高性价比服务器租赁——企业级配置与24小时运维服务
Win11怎样安装网易有道词典_Win11安装词典教程【步骤】
linux写shell需要注意的问题(必看)
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何彻底删除建站之星生成的Banner?
高端企业智能建站程序:SEO优化与响应式模板定制开发
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件


