- 在线时间
- 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
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
m. ~. ^2 }1 S8 w3 \设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m+ F, a" t" Y- j0 z& S" W
a*r1≡q1 (mod n)$ `; f& p, q3 y* p! r2 m
q1*r2≡q2 (mod n)- H( ~ M6 o( u. @8 L: n
q2*r3≡q3 (mod n)
! `; O2 R, Q: D# ~, m+ O$ p4 s8 w .
( O- M1 V, N5 s0 d! j .5 G8 q( ]; K6 H* G2 m. l& {% R0 _
.
3 @( y0 ^* c$ h( {9 A7 O qm-1*rm≡qm (mod n)5 m" j+ G& F0 k7 D# f
上述等式相乘,得:
& |8 O r4 L% E+ z, f a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>
( |% Z4 Q6 V b3 s: h- C: f' N' i a*(q1*q2*...*qm)≡rm (mod n)
9 B! t8 M5 W% E& k8 W( g% O 如果对qi(1≤i≤m)进行如下的限定:
+ U9 O- g* E H2 N! R1 o/ D$ B a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|$ f: W) k G7 b. O
则 qm=±1( ]/ |+ ?: ]6 o& x9 D7 _
即 a与q1*q2*...*qm互逆8 u9 |7 h7 ~# Q) q
例 求28在299的逆
! f1 x8 `. x+ ~ 28*11≡9 (mod 299)
: o4 Y. c; G" B, m9 A R$ | 9*33≡-2 (mod 299)
/ f$ i7 K$ m: z1 K" g) r -2*-150≡1 (mod 299)4 a/ N- G9 P# k
逆为: 11*33*-150≡-32 (mod 299)
; n; K, m3 [2 i% }$ k 28*-22≡-1 (mod 299)
' d' Z" W+ r; Z9 g1 R, o O 但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
0 ?/ x6 W0 G* U/ s8 p9 W& U- Z 下面给出其中一个算法:
, c x! b. [" f& Q- \# G, y0 x 1 输入a,n
/ t' H$ e! ^& s. I% l0 q 2 resulte = 1 ; 保存逆的结果 5 a+ r+ D4 N# j
3 r=n/a+1 ; 保证 r*a>n% F( O% @3 t" t! S% S. E) ^
4 q=r*a-n ; 得到余数,该余数小于a
9 w: }+ E9 h4 s% H 5 resulte=(resulte*r)%n . n$ }' P8 Q/ e) A. a
6 if q=1 then print(逆为: resulte) return resulte
) {/ F4 x. Y! M/ e6 N2 J 7 if q=0 or q=a then print(存在因子: a) return a ; T! W( \$ L) C2 q
8 a=q( u" p% F- y" ~& d; G3 u( y. A
9 goto 3
3 k ~) O8 s6 ]- [
$ ~+ C( g0 ^. x6 S |
zan
|