| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 扩展欧几里得算法及其简单应用 -> 正文阅读 |
|
[数据结构与算法]扩展欧几里得算法及其简单应用 |
扩展欧几里得算法1. 整除与取模先普及一下整除符号“|” 然后是取模运算 取模运算不用说,大家都懂,不过有几条性质希望大家也都明白。 (a+b)%m = (a%m + b%m ) %m; (a-b)%m = (a%m - b%m ) %m; (a*b)%m = (a%m * b%m ) %m; 除法在这里是不成立的:(a/b)%m = (a%m / b%m ) %m; 这是错误的 2. 欧几里得算法g c d ( a , b ) = g c d ( b , a % b ) gcd(a,b)=gcd(b,a\% b) gcd(a,b)=gcd(b,a%b) 若a<b,则gcd(a,b)=gcd(b,a)=gcd(b,a% b),命题成立。 若a>=b,不妨设a=q*b+r,其中0≤r<b。显然r=a%b。 如果觉得不自然,请再往下看。 假设(a,b)>(b,a%b),令d等于a,b的最大公约数,即d=(a,b)) 3. 最大公约数、最小公倍数
4. 扩展欧几里得算法满足ax+by=(a,b) 时,可以用扩展欧几里得算法求出一组特解 ( x0 , y0 )
a x + b y = b x + ( a % b ) y = a y + ( x ? a / b ? y ) b 于 是 我 们 可 以 不 断 递 归 至 b = 0 , 使 得 a x + b y = ( a , 0 ) = a , x = 1 , y = 0 ; ax+by = bx+(a\%b)y = ay + ( x -a/b*y)b\\ 于是我们可以不断递归至b=0,使得\\ ax+by=(a,0)=a,x=1,y=0; ax+by=bx+(a%b)y=ay+(x?a/b?y)b于是我们可以不断递归至b=0,使得ax+by=(a,0)=a,x=1,y=0; 5. ax+by=n5.1 有解条件当 且 仅 当 n 是 g c d ( a , b ) 的 倍 数 时 , 才 有 整 数 解 。 当且仅当n是gcd(a,b)的倍数时,才有整数解。 当且仅当n是gcd(a,b)的倍数时,才有整数解。 5.2 求解步骤1. 判 断 a x + b y = n 是 否 有 整 数 解 , 有 解 的 条 件 是 g c d ( a , b ) ∣ n 2. 求 a x + b y = d = ( a , b ) 的 一 个 解 ( x 0 , y 0 ) 3. 在 得 到 的 a x 0 + b y 0 = d 两 边 同 时 乘 n / d 得 到 ?? a x 0 ? n / d + b ??? y 0 ? n / d = n 4. 对 照 a x + b y = n 得 到 它 的 一 个 解 x = x 0 ? n / d , ?? y = y 0 ? n / d 5. 它 的 通 解 表 达 式 为 ? x = x + b / d ???? y = y ? a / d 1.判断ax+by=n 是否有整数解,有解的条件是 gcd(a,b)|n\\ 2.求ax+by= d=(a,b) 的一个解 (x_0, y_0) \\ 3.在得到的 ax_0+by_0 = d 两边同时乘 n/d 得到 \ \ ax_0 *n/d+b\ \ \ y_0 *n/d = n\\ 4.对照 ax+by=n 得到它的一个解 x = x_0 *n/d,\ \ y = y_0 *n/d \\ 5.它的通解表达式为 \ x=x+b/d\ \ \ \ y=y-a/d\\ 1.判断ax+by=n是否有整数解,有解的条件是gcd(a,b)∣n2.求ax+by=d=(a,b)的一个解(x0?,y0?)3.在得到的ax0?+by0?=d两边同时乘n/d得到??ax0??n/d+b???y0??n/d=n4.对照ax+by=n得到它的一个解x=x0??n/d,??y=y0??n/d5.它的通解表达式为?x=x+b/d????y=y?a/d 如果要求x的最小正整数解,令t=b/d x=(x%t+t)%t; 求y同理 5.3 代码
6. 同余方程1.同余两个整数a、b和正整数m ,如果a除以m所得的余数和b除以m所得的余数相等,即a %m=b%m. 称a和b对于m同余.m称为同余的模。同余的概念也可以这样理解: m l(a-b)。即a-b是m的整数倍。 例如 6|(16-4)16和4对6同余。同余的符号记为 2.同余方程a x ≡ b ( m o d ? m ) ax \equiv b(mod \ m) ax≡b(mod?m)
a
x
?
b
是
m
的
整
数
倍
,
即
满
足
a
x
?
b
=
m
y
??
其
中
y
可
以
是
负
数
于
是
可
以
改
写
为
a
x
+
m
y
=
b
ax-b 是m的整数倍,即满足ax-b=my \ \ 其中y可以是负数\\ 于是可以改写为 ax+my=b
ax?b是m的整数倍,即满足ax?b=my??其中y可以是负数于是可以改写为ax+my=b 7. 逆元什么是逆元?百度百科:逆元 这里只讨论我们需要的乘法逆元:
除法取模逆元有什么用? 求(a/b)%m,当a,b是很大的数时,作除法会损失精度 使用逆元可以避免除法:设k是b的逆元,则bk模m等于1 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 9:32:42- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |