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

欧几里得 ---> 裴蜀定理 ---> 拓展欧几里得

文章目录

  • 欧几里得 ---> 裴蜀定理 ---> 拓展欧几里得
    • 基本内容
      • 求逆元
    • 证明
      • 欧几里得算法(辗转相除法)
      • 裴蜀定理
      • 扩展欧几里得定理
    • 题目运用
      • 裴蜀定理
        • 代码
      • 扩展欧几里得
        • [P1082 [NOIP 2012 提高组\] 同余方程 - 洛谷](https://www.luogu.com.cn/problem/P1082)
          • 代码
        • [P5656 【模板】二元一次不定方程 (exgcd) ](https://www.luogu.com.cn/problem/P5656)

欧几里得 —> 裴蜀定理 —> 拓展欧几里得

基本内容

概念解决的问题核心方法提出者/背景
欧几里得算法计算两个整数的GCD辗转相除法 gcd ⁡ ( a , b ) = gcd ⁡ ( b , a m o d b ) \gcd(a, b) = \gcd(b, a \bmod b) gcd(a,b)=gcd(b,amodb)欧几里得(公元前300年)
裴蜀定理判断线性方程 (ax + by = m) 是否有解存在性定理:解存在当且仅当 (m) 是 gcd ⁡ ( a , b ) \gcd(a, b) gcd(a,b)的倍数裴蜀(18世纪)
扩展欧几里得算法求解方程 a x + b y = gcd ⁡ ( a , b ) ax + by = \gcd(a, b) ax+by=gcd(a,b)的解递归反向推导系数,结合模运算回溯算法演进(19世纪后)

求逆元

费马小定理求逆元,模数需要是质数。扩展欧几里得求逆元只需 a 与 m 互质

在这里插入图片描述

证明

欧几里得算法(辗转相除法)

核心定理:对于任意整数 (a, b) ( a ≥ b ≥ 0 ) (a \geq b \geq 0) (ab0),有 gcd ⁡ ( a , b ) = gcd ⁡ ( b , a m o d b ) \gcd(a, b) = \gcd(b, a \bmod b) gcd(a,b)=gcd(b,amodb)
证明步骤

  1. 余数性质:设 (a = bq + r)(其中 r = a m o d b r = a \bmod b r=amodb),则 (a) 和 (b) 的公约数必然也是 (b) 和 (r) 的公约数,反之亦然。
    • d ∣ a d \mid a da d ∣ b d \mid b db,则 $ d \mid (a - bq) = r$。
    • d ∣ b d \mid b db d ∣ r d \mid r dr,则 $ d \mid (bq + r) = a$。
  2. 数学归纳法
    • 基例:当 (b = 0) 时,(\gcd(a, 0) = a),显然成立。
    • 归纳假设:假设对 (b < k) 时定理成立。
    • 归纳步骤:当 (b = k) 时,通过余数 (r = a \bmod b) 递归缩小问题规模,最终余数为零时,非零余数即为 GCD。
      应用场景:快速计算两个数的最大公约数,例如分数约分、素数检测等。

内容引用自:董晓 - 博客园

裴蜀定理



在这里插入图片描述

扩展欧几里得定理




在这里插入图片描述

  1. 求不定方程 a x + b y = g c d ( a , b ) ax+by=gcd(a,b) ax+by=gcda,b
  2. 求解同余方程
  3. 求解乘法逆元

时间复杂度:O(log n)

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

题目运用

裴蜀定理

P4549 【模板】裴蜀定理 - 洛谷

img

代码
int a[N];
void solve()
{int n,s=0;cin>>n;fir(i,1,n)   {cin>>a[i];s=__gcd(s,abs(a[i]));}         cout<<s<<'\n';
}

扩展欧几里得

[P1082 NOIP 2012 提高组] 同余方程 - 洛谷

img

x%y= x-(x/y) * y

对 b 取模,可以看作 **+b y ** (y为负值)

所以式子可以转化为

ax+by=1

求 x 的解。

代码
int x,y,a,b;
void exgcd(int a,int b)
{if(b==0){x=1,y=0;return ;}exgcd(b,a%b);int te=x;x=y;y=te-a/b*y;return ;
}
void solve()
{cin>>a>>b;exgcd(a,b);x=(x%b+b)%b;cout<<x<<'\n';
}
P5656 【模板】二元一次不定方程 (exgcd)

题目:判断 ax+by =c 的解

  • c ! = gcd(a,b) 无解
  • 用加减 p , q 求通解
int a,b,c,x,y;
void exgcd(int a,int b)
{if(b==0){x=1,y=0;return;}exgcd(b,a%b);int t=x;x=y,y=t-a/b*y;return;
}
void solve()
{x=0,y=0;cin>>a>>b>>c;if(c%__gcd(a,b)!=0) cout<<"-1\n";else {exgcd(a,b);int d=a*x+b*y;//公因数x*=c/d,y*=c/d;//int p=b/d,q=a/d;if(x<=0){int k=(1-x+p-1)/p;x+=k*p;y-=k*q;}else {int k=(x-1)/p;x-=k*p;y+=k*q;}if(y<=0) {int k=(1-y+q-1)/q;y+=k*q;cout<<x<<' '<<y<<'\n';//x,y最小正整数解}else{cout<<(y-1)/q+1<<' ';        //y减到1的方案数为解的个数cout<<x<<' '<<(y-1)%q+1<<' ';//最小cout<<x+(y-1)/q*p<<' '<<y<<'\n';//最大}}   
}
http://www.xdnf.cn/news/679267.html

相关文章:

  • 使用MATLAB求解微分方程:从基础到实践
  • ProfiNet转MODBUSTCP网关模块的实时性保障Logix5000控制器与AltivarProcess变频器同步控制方案
  • 【leetcode】977. 有序数组的平方
  • Microbiome|基于MAG的宏转录组
  • TailwindCSS v4 快速入门教程
  • 在Linuxfb环境下利用海思TDE API实现高效的2D图形加速
  • Java中的日期类详解
  • 数据泄露频发,Facebook的隐私保护是否到位?
  • 12. CSS 布局与样式技巧
  • [网页五子棋][用户模块]数据库设计和配置(MyBatis)、约定前后端交互接口、服务器开发
  • 使用tunasync部署企业内部开源软件镜像站-Centos Stream 9
  • 用ChatGPT辅助UI设计:从需求分析到风格提案的提效秘籍
  • 代码随想录算法训练营第五十一天
  • Day4 记忆内容:priority_queue 高频操作
  • SAAS架构设计2-流程图-注册流程图
  • uni-app 中开发问题汇总
  • 【网络编程】十七、多路转接之 epoll
  • JAVA SE 文件IO
  • Python函数
  • python+tkinter实现GUI界面调用即梦AI文生图片API接口
  • PPO算法里clipfrac变量的作用
  • 《计算机组成原理》第 7 章 - 指令系统
  • 恶意npm与VS Code包窃取数据及加密货币资产
  • 科研级计算服务器 稳定支撑创新研究
  • 系统设计——项目设计经验总结3
  • int c =5; 代码解释
  • 《计算机组成原理》第 5 章 - 输入输出系统
  • 冒泡排序:像煮汤一样让数字「冒泡」
  • centos7安装MySQL(保姆级教学)
  • Linux信号量(32)