欧几里得定理专题
一、欧几里得定理
1. 同余定理
注意:除法没有同余的性质,需要求逆元。
2. 欧几里得定理
3. 欧几里得定理用法
(1) 求最大公约数
//最大公约数,辗转相除法
int gcd(int a, int b) {
if (b == 0) return a;
return gcd(b, a % b);
}
(2) 求最小公倍数
//最小公倍数
int lcm(int a, int b) {
return a * b / gcd(a, b);
}
二、扩展欧几里得定理
1. 定义
,在已知的情况下求解出一组(特解)。
2. 推导过程
根据欧几里得定理,有:
用代替的位置,用代替的位置,得到:
因为 ,代入方程,得到:
变形
与方程对比系数,得到
这就是扩展欧几里得算法中关键代码的由来。
int exgcd(int a, int b, int &x, int &y) {//返回gcd(a,b) 并求出解(引用带回)
if (b == 0) {
x = 1, y = 0;
return a;
}
int x1, y1, gcd;
gcd = exgcd(b, a % b, x1, y1);
x = y1, y = x1 - a / b * y1;
return gcd;
}
简化一下:
//yxc写法
int exgcd(int a, int b, int &x, int &y) {
if (!b) {
x = 1, y = 0;
return a;
}
int d = exgcd(b, a % b, y, x);
y -= a / b * x;
return d;
}
3.性质
-
若通过扩展欧几里得求出一组特解(,),那么有。
则方程的通解为: 其中为任意整数, -
已知的解,对于的解,为任意正整数,只有当时才有解,
则方程的通解为: 其中为任意整数,
4.常见用法
(1)求形如的通解,或从中选取某些特解。
(2)求乘法逆元
(3)求解线性同余方程(组)
5.解题思路
-
先将问题转化成不定方程
-
参数取正数,判断是否为负数,为负数就都乘上,另外注意若中只有一个是负数,那另一个不需要乘,因为本身是含未知数参数的。
-
,然后判断是否有解采用
-
求特解:, ;
-
求通解: , (其中 为整数)
-
求最小解:; ;
6.例题实例
问题描述:对于 的不定方程求通解或特解?
设 ,
若 此方程无整数解
若 ,
特解:
,
通解:
, (其中 为整数)
最小解:
https://www.cnblogs.com/yaochen/p/10894280.html?share_token=23191250-107c-4b7f-a6c4-f4139ee37033
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
2016-10-08 工资系统解决办法
2016-10-08 控制其它程序