扩展的欧几里得算法求逆元的思想和过程
时间: 2023-09-30 17:09:27 浏览: 82
扩展的欧几里得算法可以用来计算两个整数 a 和 b 的最大公约数 gcd(a,b),并且可以找到一对整数 x 和 y,使得 ax+by=gcd(a,b)。当 a 和 b 互质时,即 gcd(a,b)=1 时,我们称 y 为 a 的模 b 的逆元,记为 a^-1。
下面是扩展的欧几里得算法的思想和过程:
1. 首先使用欧几里得算法计算 gcd(a,b)。
2. 如果 b=0,则 gcd(a,b)=a,此时 x=1,y=0。
3. 否则,递归调用扩展的欧几里得算法,得到一组 x1 和 y1,使得 b*x1+(a mod b)*y1=gcd(b,a mod b)。
4. 根据欧几里得算法的定义,有 gcd(a,b)=gcd(b,a mod b),因此 gcd(a,b)=b*x1+(a mod b)*y1。
5. 由于 a mod b=a-floor(a/b)*b,可以将上式改写为 gcd(a,b)=b*x1+(a-floor(a/b)*b)*y1。
6. 整理得到 gcd(a,b)=a*y1+b*(x1-floor(a/b)*y1)。
7. 因此,我们可以令 x=y1,y=x1-floor(a/b)*y1,得到一组满足 ax+by=gcd(a,b) 的整数解 x 和 y。
8. 如果我们需要求 a 的模 b 的逆元,我们需要判断 gcd(a,b) 是否等于 1。如果 gcd(a,b) 不等于 1,则 a 没有模 b 的逆元;如果 gcd(a,b) 等于 1,则根据上面的公式计算出 a 的模 b 的逆元为 y。
至此,我们完成了扩展的欧几里得算法求逆元的思想和过程。
相关问题
扩展欧几里得算法求逆元c语言,关于扩展欧几里得算法和逆元
扩展欧几里得算法是求解一元一次不定方程 ax + by = gcd(a,b) 的一种方法,其中 a 和 b 是整数,gcd(a,b) 是它们的最大公约数,x 和 y 是整数解。逆元是指在模运算下,一个数的乘法逆元是指与它相乘后模运算得到 1 的数。在数论中,常常需要求一个数在模意义下的逆元,即一个数 k 满足 (k * x) % m = 1,其中 m 是模数。
下面是扩展欧几里得算法求逆元的 C 语言实现:
```c
#include <stdio.h>
// 扩展欧几里得算法
int exgcd(int a, int b, int *x, int *y) {
if (b == 0) {
*x = 1;
*y = 0;
return a;
}
int gcd = exgcd(b, a % b, y, x);
*y -= a / b * (*x);
return gcd;
}
// 求逆元
int modinv(int a, int m) {
int x, y;
int gcd = exgcd(a, m, &x, &y);
if (gcd != 1) {
return -1; // a 和 m 不互质,不存在逆元
} else {
return (x % m + m) % m; // 转化为正整数
}
}
int main() {
int a = 3, m = 11;
int inv = modinv(a, m);
if (inv == -1) {
printf("%d 在模 %d 意义下不存在逆元\n", a, m);
} else {
printf("%d 在模 %d 意义下的逆元是 %d\n", a, m, inv);
}
return 0;
}
```
这个程序中,exgcd 函数通过递归实现扩展欧几里得算法,返回 a 和 b 的最大公约数,并且求出 x 和 y 的值。在 modinv 函数中,我们调用 exgcd 函数求出 a 和 m 的最大公约数,并且判断 a 和 m 是否互质,如果不互质则不存在逆元。否则,根据扩展欧几里得算法的结果,求出 x 的值作为 a 在模 m 意义下的逆元。注意,由于 x 可能是负数,所以要将其转化为正整数。
扩展的欧几里得算法求逆元的思想
扩展的欧几里得算法是求解一元线性同余方程 ax ≡ b(mod n) 的经典算法,其中a、b、n是给定的整数,x是未知的整数。如果a和n互质,则方程有唯一解。否则,方程有无穷多解。此时,我们可以用扩展的欧几里得算法求解方程的通解。
扩展的欧几里得算法的基本思想是利用欧几里得算法求出a和n的最大公约数gcd(a, n),并且利用辗转相除的过程中得到gcd(a, n)的一组贝祖等式:gcd(a, n) = ax + ny,其中x和y是整数。然后,我们可以通过变换贝祖等式得到方程的通解。
接下来我们考虑如何用扩展的欧几里得算法求解求逆元的问题。设a和n是两个互质的整数,那么根据费马小定理,有a^{φ(n)} ≡ 1(mod n),其中φ(n)是n的欧拉函数。因此,a^{φ(n)-1} 是a在模n下的逆元。要求a在模n下的逆元,我们需要先求出φ(n),然后求出a^{φ(n)-1}。这个过程可以利用扩展的欧几里得算法来实现。
具体地,我们可以将a和n带入扩展的欧几里得算法,求出gcd(a,n)和一组贝祖等式gcd(a, n) = ax + ny,如果gcd(a,n)=1,那么x就是a在模n下的逆元。如果gcd(a,n)≠1,那么a在模n下不存在逆元。
综上所述,扩展的欧几里得算法求逆元的思想是,利用扩展的欧几里得算法求出a和n的最大公约数和一组贝祖等式,然后根据贝祖等式得到方程的通解,从而求出a在模n下的逆元。
阅读全文