数论2:gcd、lcm与exgcd

news/2026/1/18 22:01:20/文章来源:https://www.cnblogs.com/KeyuanTechno/p/19498367

gcd:Greatest Common Divisor,最大公约数,即对于不全为0的整数p、q,存在一最大的整数r,使得r|p、r|q且对于任意整数s,s|p且s|q,有r>=s。
记作gcd(p,q),特别的,gcd(a,0) = |a| (a!=0).
lcm:Least Common Multiple,最小公倍数,即对于两个非零整数p、q,存在一最小的整数r,使得p|r、q|r且对于任意整数s,p|s且q|s,有r<=s。
记作lcm(p,q),特别的,lcm(a,0) = 0.

一般通过欧几里得算法计算gcd(p,q),而lcm(p,q)通过p*q/gcd(p,q)得到。

下面介绍欧几里得算法(辗转相除法)

核心:gcd(a,b) = gcd(b,a%b).
证明:设a = b*k + c, 则 c = a % b.假设d是a、b的公约数,那么由c = a - b*k可得 c/d = a/d - b/d * k
因为d|a、d|b,a/d和b/d为整数,那么可知c/d也是整数,即d为a、b、c的公约数

反之假设d是b、c的公约数,那么由a = b*k + c可得 a/d = b/d * k + c/d,那么d也为a、b、c的公约数

故a,b的公约数等于b,a%b的公约数,那么自然有gcd(a,b) = gcd(b,a%b).

c++实现如下:

int gcd(int a, int b){if(b = 0) return abs(a);return gcd(b, a % b);
}

时间复杂度为O(log(max(a,b)))

int lcm(int a, int b){if(a == 0 || b == 0) return 0;return a * b / gcd(a, b);
}

视情况而定,有时候可能要用到高精度乘法(这里可以先计算a/gcd(a,b)或b/gcd(a,b)避免使用高精度除法)

更相减损术
对于大整数,取模运算耗时较长,这时候依据gcd(a, b) = gcd(min(a, b), max(a, b) - min(a, b))可以较快的找到最大公约数,但是要使用到高精度减法

对于多个数a1、a2……an的最大公约数,有:gcd(a1, a2, ……, an) = gcd(gcd(a1, a2, ……, an-1), an)的递归关系。
而lcm(a1, a2, ……, an) = a1a2……*an / gcd(a1, a2, ……,an)^(n-1)。

拓展欧几里得算法(exgcd)
拓展欧几里得算法用于求解一次线性方程ax+by=gcd(a,b)的解。
注意,对于方程ax+by=c,只有gcd(a,b)|c时,x,y才有整数解,即feishudingligcd:Greatest Common Divisor,最大公约数,即对于不全为0的整数p、q,存在一最大的整数r,使得r|p、r|q且对于任意整数s,s|p且s|q,有r>=s。
记作gcd(p,q),特别的,gcd(a,0) = |a| (a!=0).
lcm:Least Common Multiple,最小公倍数,即对于两个非零整数p、q,存在一最小的整数r,使得p|r、q|r且对于任意整数s,p|s且q|s,有r<=s。
记作lcm(p,q),特别的,lcm(a,0) = 0.

一般通过欧几里得算法计算gcd(p,q),而lcm(p,q)通过p*q/gcd(p,q)得到。

下面介绍欧几里得算法(辗转相除法)

核心:gcd(a,b) = gcd(b,a%b).
证明:设a = b*k + c, 则 c = a % b.假设d是a、b的公约数,那么由c = a - b*k可得 c/d = a/d - b/d * k
因为d|a、d|b,a/d和b/d为整数,那么可知c/d也是整数,即d为a、b、c的公约数

反之假设d是b、c的公约数,那么由a = b*k + c可得 a/d = b/d * k + c/d,那么d也为a、b、c的公约数

故a,b的公约数等于b,a%b的公约数,那么自然有gcd(a,b) = gcd(b,a%b).

c++实现如下:

int gcd(int a, int b){if(b = 0) return abs(a);return gcd(b, a % b);
}

时间复杂度为O(log(max(a,b)))

int lcm(int a, int b){if(a == 0 || b == 0) return 0;return a * b / gcd(a, b);
}

视情况而定,有时候可能要用到高精度乘法(这里可以先计算a/gcd(a,b)或b/gcd(a,b)避免使用高精度除法)

更相减损术
对于大整数,取模运算耗时较长,这时候依据gcd(a, b) = gcd(min(a, b), max(a, b) - min(a, b))可以较快的找到最大公约数,但是要使用到高精度减法

对于多个数a1、a2……an的最大公约数,有:gcd(a1, a2, ……, an) = gcd(gcd(a1, a2, ……, an-1), an)的递归关系。
而lcm(a1, a2, ……, an) = a1a2……*an / gcd(a1, a2, ……,an)^(n-1)。

拓展欧几里得算法(exgcd)
拓展欧几里得算法用于求解一次线性方程ax+by=gcd(a,b)的解。
注意,对于方程ax+by=c,只有gcd(a,b)|c时,x,y才有整数解,即裴蜀定理

下面讲解exgcd如何求出ax+by=gcd(a,b)ax+by=c(gcd(a,b)|c)的特解与通解。

我们知道,gcd(a,b) = gcd(b, a%b), 则有ax + by = bx' + (a%b)y',将a%b代换为a- a/b * b(注意此处的a/b是整除

展开可得ax + by = bx' + ay' - (a/b * b)y'
整理得x = y', y = x' - a/b*y'

由此设计exgcd算法,可以在得到gcd(a,b)的同时算出x、y的一组特解
特别的,当b = 0时,gcd(a, b) = a(a>0), x = 1, y = 0;

故有如下exgcd代码:

int exgcd(int a, int b, int& x, int& y){if(b == 0){x = 1, y = 0;return a;}int d = exgcd(b, a % b, x, y);int t = x;x = y;y = t - a/b * y;return d;
}

这时得到一组特解(x0, y0)与g = gcd(a, b, x, y),而其通解为
x=x0+k*(b/g)
y=y0-k*(a/g)

x的最小非负值为(x%(b/g) + (b/g)) % (b/g),x为任意一组解的x;
y的最小非负值为(y%(a/g) + (a/g)) % (a/g),a为任意一组解的y;
注意,此处的两个最小非负值一般不同时取到,除非只有一个k对应唯一一组非负解(非负解:x、y均非负的一组解)。

若要求非负解是否存在,可从x>0与y>0这个方程组中,k整数解的情况判断,同时还能得知x、y的最大/最小非负值。P5656 【模板】二元一次不定方程 (exgcd)

一般在确定gcd(a,b)|c后,可以直接对ax+by=c使用exgcd,就能通过相似的过程得到解,但是要乘上c/d(d = gcd(a,b))来缩放x与y。原因在于,当c=k*d时,实际运算的式子是ax'+by'=gcd(a,b),算出来的式子与目标式子左右少一个c/d的系数。

关于ax+by=c的整数解,还有如下推导:
d=gcd(a,b),c=k*d,必有整数a'、b'满足a'd = ab'd = b,那么有a'dx + b'dy = kd,即a'x + b'y = k,其中gcd(a', b')=1,即a'与b'互质。

那么我们可以考虑对方程a'x + b'y = 1使用exgcd算法,那么就可以得到x,y的特解与通解。

exgcd算法有着广泛的应用,如求模逆元。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1179567.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

假期schedule

写在前面 假期雅思是最重要的 计划安排 5.40-5.50 起床 6.00 - 7.00 口语一节词汇课 7.30 - 9.30 第一节回放 10.00 开始第二节回放看一点可能去吃饭 尽量不要午睡 下午最好1.30 可以开始胡小溪或邹为涛 一周要保证六天&#xff0c;六个下午在做研究 晚上晚饭之后看完一个雅思回…

计算机小程序毕设实战-基于SpringBoot+Vue的高校学科竞赛管理系统微信小程序基于springboot+微信小程序的院竞赛管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

day144—递归—平衡二叉树(LeetCode-110)

题目描述给定一个二叉树&#xff0c;判断它是否是 平衡二叉树 示例 1&#xff1a;输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;true示例 2&#xff1a;输入&#xff1a;root [1,2,2,3,3,null,null,4,4] 输出&#xff1a;false示例 3&#xff1a;输入&…

2026年市场可靠的活性炭箱优质厂家哪家靠谱,滤筒除尘器/旋风除尘器/活性炭箱/催化燃烧,活性炭箱生产商口碑排行 - 品牌推荐师

评测背景 随着环保政策持续收紧及工业废气治理需求激增,活性炭箱作为VOCs(挥发性有机物)治理的核心设备,其性能稳定性、技术适配性及服务能力成为用户选型的关键指标。为客观评估市场主流供应商的综合实力,本评测…

STM32单片机分享:智能鱼缸系统

目录 一、项目成品图片 二、项目功能简介 1.主要器件组成 2.功能详解介绍 三、项目原理图设计 四、项目PCB硬件设计 项目PCB图 五、项目程序设计 六、项目实验效果 ​编辑 七、项目包含内容 一、项目成品图片 哔哩哔哩视频链接&#xff1a; https://www.bilibili.c…

2026年国内可靠的活性炭箱制造厂家推荐排行榜,RTO/旋风除尘器/沸石转轮一体机/除尘器,活性炭箱公司推荐榜 - 品牌推荐师

在工业废气治理领域,活性炭箱作为VOCs(挥发性有机物)吸附净化环节的核心设备,直接影响企业排放达标率与环保合规成本。其吸附效率、结构稳定性及运维便捷性,已成为衡量设备性能的关键指标。本文聚焦河北清大环保机…

交通仿真软件:VISSIM_(22).交通仿真在城市规划中的应用

交通仿真在城市规划中的应用 1. 交通仿真概述 交通仿真是一种通过计算机模型来模拟实际交通系统运行情况的技术。它可以帮助城市规划师、交通工程师和政策制定者在虚拟环境中评估和优化交通系统的性能。交通仿真软件通过创建详细的交通网络模型&#xff0c;模拟车辆、行人和公共…

day145—递归—二叉树的右视图(LeetCode-199)

题目描述给定一个二叉树的 根节点 root&#xff0c;想象自己站在它的右侧&#xff0c;按照从顶部到底部的顺序&#xff0c;返回从右侧所能看到的节点值。示例 1&#xff1a;输入&#xff1a;root [1,2,3,null,5,null,4]输出&#xff1a;[1,3,4]解释&#xff1a;示例 2&#xf…

STM32单片机分享:智能书桌系统

目录 一、项目成品图片 二、项目功能简介 1.主要器件组成 2.功能详解介绍 三、项目原理图设计 四、项目PCB硬件设计 项目PCB图 五、项目程序设计 六、项目实验效果 ​编辑 七、项目包含内容 一、项目成品图片 哔哩哔哩视频链接&#xff1a; https://www.bilibili.c…

理性选择RTO:基于用户反馈的供货商横向评测,沸石转轮/活性炭箱/RTO/沸石转轮一体机,RTO源头厂家排行榜 - 品牌推荐师

引言 在工业废气治理领域,RTO(蓄热式废气焚烧设备)作为处理VOCs(挥发性有机物)的关键设备,其性能与可靠性直接关系到企业能否稳定达标排放、实现绿色生产与可持续发展。面对市场上众多的RTO设备供应商,如何选择…

2026苏州新房装修大揭秘:这些服务优质的公司你不能错过! - 品牌测评鉴赏家

2026苏州新房装修大揭秘:这些服务优质的公司你不能错过!一.装修前的准备 装修新房是一件令人兴奋又充满挑战的大事,它承载着我们对未来美好生活的憧憬。而在苏州这个充满韵味的城市,选择一家服务好的新房装修公司至…

小程序计算机毕设之基于微信小程序的大学生科技竞赛管理系统的设计与实现基于springboot+微信小程序的院竞赛管理系统(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

Flink Elasticsearch Connector 从 0 到 1 搭一个高吞吐、可容错的 ES Sink

1. 先说版本现状&#xff1a;Flink 2.2 目前还没有可用的 ES Connector 依赖 如果你在看 Flink 2.2 的官方文档&#xff0c;会看到一个非常关键的提示&#xff1a; DataStream 的 Elasticsearch 6.x/7.x connector&#xff1a;Flink 2.2 暂无可用 connector (Apache Nightlie…

Flink Firehose Sink 把实时流数据稳定写进 Amazon Kinesis Data Firehose

1、先看版本坑&#xff1a;Flink 2.2 目前没有可用的 Firehose Connector 如果你正在用 Flink 2.2&#xff0c;官方文档明确写了&#xff1a;Flink 2.2 暂无可用的 Firehose connector&#xff1b;PyFlink 侧也标注 暂无 SQL jar。 (nightlies.apache.org) 如果你用的是已发布…

GESP认证C++编程真题解析 | 202309 五级

​欢迎大家订阅我的专栏:算法题解:C++与Python实现! 本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战! 专栏特色 1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的…

vscode的.vscode文件记录

tasks.json&#xff1a;控制如何编译你的代码&#xff08;加 -I参数&#xff09; launch.json&#xff1a;控制如何调试你的代码&#xff08;指定调试器路径&#xff09;launch.json文件{"version": "0.2.0","configurations": [{"name&quo…

人工智能之数据分析 Pandas:第九章 性能优化 - 实践

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2026年国内最好的沸石转轮+CO定制厂家口碑推荐榜单,除尘器/沸石转轮一体机/滤筒除尘器/催化燃烧,沸石转轮生产商排名 - 品牌推荐师

随着工业废气治理需求持续攀升,沸石转轮+CO(催化燃烧)技术凭借高效吸附与低温催化优势,成为VOCs治理领域的核心解决方案。然而,市场鱼龙混杂,企业技术实力、设备稳定性及售后服务差异显著。为此,我们通过全网数…

小程序毕设项目:基于springboot+微信小程序的院竞赛管理系统(源码+文档,讲解、调试运行,定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

开发智力的课堂

假期充电模式&#xff0c;小朋友认真上课的样子&#xff0c;别人的假期在玩耍&#xff0c;娃们的假期在赶课&#xff0c;努力的小孩最可爱&#xff0c; 假期不虚度&#xff0c;成长不止步&#xff0c;课堂上的小身影&#xff0c;正在悄悄积攒能量&#xff0c;收获满满[太阳][跳…