0

0

C++ 怎么求最小公倍数 C++ gcd辅助计算lcm代码【逻辑】

冰火之心

冰火之心

发布时间:2026-01-29 07:17:36

|

129人浏览过

|

来源于php中文网

原创

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。

c++ 怎么求最小公倍数 c++ gcd辅助计算lcm代码【逻辑】

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;
}

注意点:

DALL·E 2
DALL·E 2

OpenAI基于GPT-3模型开发的AI绘图生成工具,可以根据自然语言的描述创建逼真的图像和艺术。

下载
  • 务必取绝对值,否则负数取模行为在 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)),虽然数学等价,但顺序影响中间结果大小,可能加剧溢出风险(例如 bclcm 已很大,再跟 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 的数压一压。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

94

2023.09.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

544

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

93

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

93

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

102

2025.10.23

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

396

2023.07.18

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号