当前位置: 首页 > news >正文

数学知识

exgcd(拓展欧几里得算法)

exgcd,常用于解决形如 \(ax+by=gcd(a,b)\) 的方程。
容易知道,\(gcd(a,b)=gcd(b,a%b)\)
所以我们可以先解出来方程 \(bx+(a%b)y=gcd(b,a%b)\)
所以这个方程如何解呢?
考虑参考辗转相除法,一路向下,最终一定出现 \(b=0\) 的情况,此时一定会出现 \(a=gcd(a,b)\),然后即可带入 \(x=1,y=0\)
于是接下来需要解决的问题就变成了通过方程 \(bx+(a%b)y=gcd(b,a%b)\) 的特解,推出方程 \(ax+by=gcd(a,b)\) 的一组特解。
换一种表现方式,原方程即可代换为 \(bx+(a-b*⌈\frac{a}{b}⌉)y=gcd(a,b)\)
也就是说,我们可以得到方程 \(ay+b(x-⌈\frac{a}{b}⌉y)=gcd(a,b)\) 记这个方程的一组特殊解为 \(x',y'\)
于是,原方程中 \(x\)\(y\) 的一组特殊解是 \(x=y',y=x'-y'\times ⌊\frac{a}{b}⌋\)
这样,我们就得到了原方程的一组特殊解。
但是,容易发现,大部分的题目都要求我们给出最小正整数解,所以我们又发现了这一性质。\(x+\frac{a}{gcd(a,b)},y-\frac{b}{gcd(a,b)}\)也是这个方程的一组特殊解,那么,我们只需要将 \(x\) 对着 \(\frac{a}{gcd(a,b)}\) 取模,搞成正的即可。

学会啦

例题

P1082 同余方程

[题目传送门]([P1082 NOIP 2012 提高组] 同余方程 - 洛谷)

这是个板子题。

要求的是方程 \(ax\equiv 1\mod b\) 的最小正整数解,那么这个式子显然可以转换为 \(ax+by=1\),因为保证有解,所以显然这两个数是互质的,所以我们直接 exgcd 做一做就差不多了。

P5656 【模板】二元一次不定方程

[题目传送门](P5656 【模板】二元一次不定方程 (exgcd) - 洛谷)

其实这才是真正的板子。

要求的方程是显然的,形式非常符合,所以考虑直接做。

判无解是好判断的,直接看 \(c=k\gcd(a,b),k\in Z\) 是否成立即可,如果不成立,直接输出 \(-1\) 就行了。

如果有解的话,我们考虑先做 \(ax+by=\gcd(a,b)\) ,然后将求出来的答案乘 \(k\) 即可。

然后,剩下的判断和之前的题目是一样的,就不细讲了。

需要注意到一点是,取模完了有可能那个数是 \(0\),这个时候重新给他加一下即可。

http://www.hskmm.com/?act=detail&tid=20324

相关文章:

  • The 3rd Universal Cup. Stage 23: Hong Kong
  • 从0到1搭建高隐蔽性C2基础设施
  • RESTful风格
  • 软工9.27
  • 一些积分的题解
  • 2025 年超声波清洗机最新权威推荐排行榜:龙门式 / 悬挂式 / 全自动等多类型设备 TOP3 品牌深度解析与选购指南
  • 问题总结,软工9.28
  • 数据类型-字符串
  • 在AI技术唾手可得的时代,挖掘新需求成为制胜关键——某知名益智游戏框架需求探索
  • 详细介绍:零基础学AI大模型之LangChain六大核心模块与大模型IO交互链路
  • 基础组合计数与卢卡斯定理
  • 2025 最新中国过滤器品牌 TOP10 权威测评推荐厂家与选购指南
  • 2025 年东莞物流公司 TOP 物流服务推荐排行榜,东莞货运物流,东莞到全国物流,东莞大型设备物流,东莞到越南物流专线东莞大件物流,东莞整车物流公司推荐!
  • 使用Python网络爬虫抓取牛客网题目
  • 题解:洛谷 P1012 [NOIP 1998 提高组] 拼数
  • day 7
  • 完整教程:Python 高效实现 PDF 转 Word:告别手动复制粘贴
  • 深入解析:C# 串口通信全解析:从基础到复杂协议的设计思路
  • P6652 「SWTR-5」String
  • 模拟退火 - 学习笔记
  • Markdown语法入门一:标题,列表,表格与字体
  • 质数筛
  • pnpm 安装后无法使用
  • 数学解题中常见的“漏解”情况分析
  • 图册
  • 简单的Powershell脚本
  • 基于YOLO8+flask+layui的行人跌倒行为检测系统【源码+模型+数据集】 - 详解
  • 环形链表-leetcode
  • [ABC425C] Rotate and Sum Query 题解
  • 线程--基本使用、线程常用方法