当前位置:网站首页>扩展欧几里得求逆元实例
扩展欧几里得求逆元实例
2022-08-03 15:33:00 【PolarDay.】
扩展欧几里得求逆元实例
首先说一下逆元的定义
存在一个数a使得ax对y进行取余运算,得到的值是1,则称a是x的逆元。在数学中记做:a * x = 1(mod p)
例如x = 4,y = 11,3x = 1(mod y),3 × 4 = 12,12 mod 11 = 1 , 3就是x的逆元。
对于求逆元这一操作在计算机领域主要用于非对称加密,如我们常见的RSA加密算法等。
那应该求得这个逆元呢,我们知道,再求两个数的最大公约数的时候可以用欧几里得算法。
在欧几里得算法中,通过辗转相除,当余数为0的时候最后的除数就是两个数的最大公约数。
而在其扩展算法中,我们已知两个数的最大公约数,我们已知 ax = 1(mod p),
展开就是 ax mod p = 1,首先我们先求 p = x1 * a + p1,然后 p = a,a = p1,迭代下去直到pi = 1(i表示出了i次)为止
然后就可以得出 1 = p - xi * a,此时的a和p已经不是我们初始的a和p了,我们需要往前推,推到 1= xa + yp 为止,此时得出的x就是a的逆元,当然如果逆元x为负数,或者比p大,要对其就行取余操作。
举个例子 11 = 1(mod 20)求11的逆元
20 = 1 × 11 + 9 //注释:此时x1 = 1, a = 11,p = 20,p1 = 9,执行p = a,a = p1
11 = 1 × 9 + 2 //注释:x2 = 1,a = 9,p2 = 2。
9 = 4 × 2 + 1 //注释:p3 = 1
此时得到:1 = 9 - 2 × 4,开始往前推直到推出 1= xa + yp
从上述式子中可以得知 9 = 20-11
1 = 20 - 11 - 2 × 4
同时 2 = 11 -9
1 = 20 -11 -4 × (11-9)
已知 9 = 20 - 11
1 = 20 -11 -4 × (11-(20-11))
1 = 20 -11 -4 × (11-20+11)
合并同类项得
1 = 5 × 20 - 9 × 11
1 = y × 20 + x × 11
x为a的逆元 -9
-9对p取余为11
综上11模20的逆元为11
验证 11 × 11 = 121,121 mod 20 = 6 — 1
到此 计算结束
边栏推荐
- 问题7:功能测试花瓶用例
- liunx服务器nohup不输出日志文件的方法
- How to use binary search and find whether the rotation in the array contains a (target) value?Rotate the sorted array leetcode 81. Search
- JS基础--判断
- 【周报】2022年7月24日
- nodeJs--跨域
- 问题10:注册页面的易用性测试?
- JS handwritten call apply bind (detailed) (interview)
- 一文搞懂$_POST和php://input的区别
- 不安装运行时运行.NET程序
猜你喜欢

美国国防部更“青睐”光量子系统研究路线

2021年12月电子学会图形化四级编程题解析含答案:棕熊大战

红蓝对抗经验分享:CS免杀姿势

Ark server opening tutorial win

身为售后工程师的我还是觉得软件测试香,转行成功定薪11.5K,特来分享下经验。

Optimal Power Flow (OPF) for High Voltage Direct Current (HVDC) (Matlab code implementation)

2021年12月电子学会图形化二级编程题解析含答案:绘制多边形

Three key expectations for the crypto market in August Price moves north?Still expected to be in turmoil

MATLAB gcf图窗保存图像,黑色背景/透明背景
![[Code Hoof Set Novice Village 600 Questions] Define a function as a macro](/img/7c/7e1469090ca3d1dea703b3fcee7428.png)
[Code Hoof Set Novice Village 600 Questions] Define a function as a macro
随机推荐
2021年12月电子学会图形化三级编程题解析含答案:跳高比赛
[Code Hoof Set Novice Village 600 Questions] Define a function as a macro
Ark server opening tutorial win
Neural networks, cool?
新版本的 MaxCompute 中,SQL支持的 LIMIT OFFSET 的语法是什么功能?
劲爆!协程终于来了!线程即将是过去式
夜神浏览器fiddler抓包
cnpm 安装成功后提示不是内部和外部命令,也不是可运行的命令解决方案
一通骚操作,我把SQL执行效率提高了10000000倍!
在 360 度绩效评估中应该问的 20 个问题
liunx服务器nohup不输出日志文件的方法
SwiftUI SQLite教程之了解如何在 SwiftUI 中使用 SQLite 数据库并执行 CRUD 操作(教程含源码)
php类的析构函数:__destruct
文件包含之伪协议的使用
JS手写call apply bind (详细)(面试)
leetcode:899. 有序队列【思维题】
2021年12月电子学会图形化四级编程题解析含答案:聪明的小猫
QT之Mysql驱动
交大医学院临床研究中心如何将 ModelWhale 应用于临床医生教学、研究丨数据科学 x 临床医学
JS handwritten call apply bind (detailed) (interview)