- 在线时间
- 7 小时
- 最后登录
- 2024-8-19
- 注册时间
- 2023-11-2
- 听众数
- 3
- 收听数
- 0
- 能力
- 0 分
- 体力
- 58 点
- 威望
- 0 点
- 阅读权限
- 20
- 积分
- 23
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 12
- 主题
- 6
- 精华
- 0
- 分享
- 0
- 好友
- 0
升级   18.95% TA的每日心情 | 郁闷 2023-12-11 09:00 |
---|
签到天数: 7 天 [LV.3]偶尔看看II
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。! u% ]7 ^( Q2 _* g
设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m5 u# c; Y }0 N1 ^1 a4 ~; Q
a*r1≡q1 (mod n)* j( ^- v/ R/ p+ M/ L: I4 ~) `0 D
q1*r2≡q2 (mod n)! ]9 y6 D, T4 z3 [- S
q2*r3≡q3 (mod n)
$ T1 l# h' A4 R4 U+ i+ Q .( E5 Q6 {6 _" V' y, d6 ^0 e
.7 ?, ^2 x) y a: ?2 J$ w2 a3 C( w
.
9 u1 Z* S7 x% K& T4 Q+ w qm-1*rm≡qm (mod n)
, b& T* u# S1 M: I9 a 上述等式相乘,得:4 c0 ]4 `+ w( l) D
a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>5 g- F; Y/ h4 m' l
a*(q1*q2*...*qm)≡rm (mod n) - w. X: `' ?* f u& y, h
如果对qi(1≤i≤m)进行如下的限定:
' ]8 x# \4 S/ v* ]; } q a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|5 z: }* t7 k) U' W
则 qm=±13 y4 L* R6 T+ b
即 a与q1*q2*...*qm互逆
* |# Y* i! U$ j" { d, l 例 求28在299的逆
/ U. X3 O. O) _: ~' {/ O5 R' z 28*11≡9 (mod 299)' g) r* {, E2 q) a( m1 d$ K7 }
9*33≡-2 (mod 299)% G! x U5 A g4 F) U% g
-2*-150≡1 (mod 299)$ \3 j3 f+ p0 S3 a$ O/ u
逆为: 11*33*-150≡-32 (mod 299)
v. R; y# r8 j; \: U2 ? 28*-22≡-1 (mod 299)
3 P) N) H+ }1 _# e 但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。# {/ B% Z/ L$ `: R
下面给出其中一个算法:
3 L$ n# h" z" t3 s 1 输入a,n
' R; t& i+ C: q S 2 resulte = 1 ; 保存逆的结果
/ u4 s+ C. _9 T; U5 g! N: _ 3 r=n/a+1 ; 保证 r*a>n
7 p: C7 u# F! _& V5 Z4 i 4 q=r*a-n ; 得到余数,该余数小于a3 x$ e0 A3 D) [) C. n* j4 `
5 resulte=(resulte*r)%n
) r' R' O' C5 D1 ^% c3 v" H 6 if q=1 then print(逆为: resulte) return resulte# \* b7 R; s+ c y4 s" k8 |& w* Q
7 if q=0 or q=a then print(存在因子: a) return a ;
" _* |6 I# j* h$ @7 V 8 a=q1 E% X2 g/ s$ D0 b2 B1 S
9 goto 3
9 z* ^* ]$ z* K2 J
( F3 j& D$ A7 h) W+ {: R |
zan
|