0

0

C++如何求最大公约数_C++自带__gcd函数及辗转相除法【数学】

穿越時空

穿越時空

发布时间:2026-02-15 14:34:03

|

763人浏览过

|

来源于php中文网

原创

__gcd不是iso c++标准函数,而是gcc扩展,msvc等编译器不支持,c++17起应使用std::gcd(需),否则需手写迭代版欧几里得算法并处理0、负数等边界情况。

c++如何求最大公约数_c++自带__gcd函数及辗转相除法【数学】

标准 C++ 不自带 __gcd,它是 GCC 扩展函数,跨平台项目中直接用会编译失败。

为什么 __gcd 不能无脑用

__gcd 不是 ISO C++ 标准函数,而是 GCC(及部分 Clang)提供的内部扩展。MSVC、Intel C++ 编译器默认不识别它;C++17 引入了 std::gcd,但需包含 <numeric></numeric> 且仅支持整型(C++20 起才支持浮点重载)。实际项目中混用会导致:

  • 在 Windows + MSVC 下编译报错:error: '__gcd' was not declared in this scope
  • Clang 开启 -pedantic 时警告 use of extension '__gcd'
  • 静态分析工具(如 clang-tidy)可能标记为不可移植代码

推荐写法:C++17 及以上用 std::gcd

只要确认编译器支持 C++17(g++ -std=c++17clang++ -std=c++17),优先使用标准库:

#include <numeric>
#include <iostream>

int main() {
    std::cout << std::gcd(48, 18) << "\n"; // 输出 6
    std::cout << std::gcd(-48, 18) << "\n"; // 输出 6(自动取绝对值)
}

注意:std::gcd 对负数自动转正处理,行为与数学定义一致;两个参数必须同为有符号或无符号整型,不能混用(如 intunsigned int 会编译失败)。

立即学习C++免费学习笔记(深入)”;

FlowMuse AI
FlowMuse AI

节点式AI视觉创作引擎

下载

兼容旧标准或需自定义逻辑时,手写辗转相除法

当目标环境不确定(如嵌入式、老编译器)、或需要处理大整数(__int128)、或想控制中间过程(比如求解贝祖系数),应手写迭代版欧几里得算法:

template<typename T>
T gcd(T a, T b) {
    while (b != 0) {
        T r = a % b;
        a = b;
        b = r;
    }
    return a < 0 ? -a : a; // 确保返回非负
}

关键点:

  • while 迭代替代递归,避免栈溢出(尤其对极大数)
  • 显式处理负号,因为 a % b 在 C++ 中符号依赖于被除数,不同编译器行为一致但易混淆
  • 模板写法支持 long longint128_t 等,比 __gcd 更灵活
  • 若需同时得到贝祖系数(即满足 ax + by = gcd(a,b)x,y),必须手写扩展欧几里得,std::gcd__gcd 都不提供该能力

容易忽略的边界情况

实际编码中这几个点常被跳过,但线上出问题往往就在这里:

  • std::gcd(0, 0) 抛出 std::domain_error(C++17 规定未定义行为,GCC 实现抛异常)
  • __gcd(0, x) 返回 abs(x),而 std::gcd(0, x) 返回 abs(x) —— 表面一致,但 __gcd(0,0) 返回 0,std::gcd(0,0) 不保证,别依赖
  • unsigned 类型时,a % b 没有符号问题,但传入 0 仍要检查,否则循环卡死
  • 若输入来自用户或文件,务必先做非零判断再进 gcd 计算,否则除零风险虽不直接出现,但逻辑可能崩

真正在意可移植性和长期维护,就别碰 __gcd;C++17 可用就用 std::gcd;否则老老实实写个几行迭代版本,顺便把 0 和负数兜住。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
while的用法
while的用法

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

102

2023.09.25

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

327

2023.10.25

string转int
string转int

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

730

2023.08.02

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

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

564

2024.08.29

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

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

214

2025.08.29

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

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

209

2025.08.29

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

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

416

2023.07.18

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.5万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.9万人学习

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

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