欧几里得定理专题

一、欧几里得定理

1. 同余定理

(a+b) % mod=(a % mod+b % mod) % mod

(ab) % mod=(a % modb % mod) % mod

(ab) % mod=(a % modb % mod) % mod

注意:除法没有同余的性质,需要求逆元。

2. 欧几里得定理

gcd(a,b)=gcd(b,a%b)

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. 定义

ax+by=gcd(a,b),在已知a,b的情况下求解出一组x0,y0(特解)。

2. 推导过程

ax+by=gcd(a,b)

根据欧几里得定理,有:
gcd(a,b)=gcd(b,a%b)

b代替a的位置,用a%b代替b的位置,得到:

bx1+(a%b)y1=gcd(a,b)

因为a%b=aabb ,代入方程,得到:

bx1+(aa/bb)y1=gcd(a,b)

变形

ay1+b(x1a/b)y1=gcd(a,b)

与方程对比系数,得到

x=y1,y=x1a/by1

这就是扩展欧几里得算法中关键代码的由来。

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.性质

  1. 若通过扩展欧几里得求出一组特解(x0,y0),那么有ax0+by0=d
    则方程的通解为: 其中k为任意整数,d=gcd(a,b)

    x=x0+k(b/d)

    y=y0k(a/d)

  2. 已知ax+by=d的解,对于ax+by=c的解,c为任意正整数,只有当d|c时才有解,
    则方程的通解为: 其中k为任意整数,d=gcd(a,b)

    x=(c/d)x0+k(b/d)

    y=(c/d)y0k(a/d)

4.常见用法

(1)求形如ax+by=c的通解,或从中选取某些特解。
(2)求乘法逆元
(3)求解线性同余方程(组)

5.解题思路

  1. 先将问题转化成不定方程ax+by=c

  2. a,b参数取正数,判断a,b是否为负数,为负数就a,b,c都乘上1,另外注意若a,b中只有一个是负数,那另一个不需要乘1,因为a,b本身是含未知数参数的。

  3. d=exgcd(a,b,x0,y0),然后判断是否有解采用if(c%d==0)

  4. 求特解:x1=x0c/d, y1=y0c/d;

  5. 求通解:x=x1+b/dt , y=y1a/dt (其中 t 为整数)

  6. 求最小解:int s=b/d; xmin=(x1%s+s)%s;

6.例题实例

问题描述:对于 ax+by=c 的不定方程求通解或特解?

d=gcd(a,b)

c%d!=0 此方程无整数解

c%d==0

特解:

x1=x0c/d , y1=y0c/d

通解:
x=x1+b/dt , y=y1a/dt (其中 t 为整数)

最小解:

d=exgcd(a,b,x0,y0);

x1=x0c/d;

int s=b/d;

xmin=(x1%s+s)%s;

https://www.cnblogs.com/yaochen/p/10894280.html?share_token=23191250-107c-4b7f-a6c4-f4139ee37033

posted @   糖豆爸爸  阅读(828)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· 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 控制其它程序
Live2D
点击右上角即可分享
微信分享提示