- 在线时间
- 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
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
0 o# X$ z& F/ Z设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m3 {& M) L9 |) q! G1 R: Q2 f, P8 m
a*r1≡q1 (mod n)& Y# J/ D, I+ B1 p% d8 i* r p p
q1*r2≡q2 (mod n)
7 p D' [: n! _9 f1 @ q2*r3≡q3 (mod n)
6 V; C! \. S" x0 g .
# o9 [5 r6 b1 E4 U% ? .
# F1 [+ }/ ~5 c6 @ .5 [ `- O) V% W2 Y/ b
qm-1*rm≡qm (mod n)
\! h0 V& t4 L/ f2 r- @; } 上述等式相乘,得:
) r0 C! G# j6 q a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>- R; V! z7 s0 J9 E3 `! ~
a*(q1*q2*...*qm)≡rm (mod n) & {6 T: U- o% L0 S8 G4 }) z: n
如果对qi(1≤i≤m)进行如下的限定:8 \1 h, ?& o6 r9 M: U
a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|& Z! D5 D- \+ @
则 qm=±1* z: z1 M& s1 B
即 a与q1*q2*...*qm互逆( W3 h1 ?& p) P' P" s/ ]# h) t
例 求28在299的逆2 ?! h$ s; O/ i# L5 d, z' v
28*11≡9 (mod 299)
4 D, G, t1 v1 g% ^, \ 9*33≡-2 (mod 299)
3 q' c! V( a4 A) c" u. e+ u' r -2*-150≡1 (mod 299)
9 Y5 |/ P; p! c8 Z 逆为: 11*33*-150≡-32 (mod 299)
' x! C0 O1 T7 E* @1 j& T2 } 28*-22≡-1 (mod 299)
. d& [8 P m# M$ S9 N7 @' _* R 但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。2 Q% X% F6 j0 ^; C& Z
下面给出其中一个算法:
) a |( P% q: ^7 n% s( ]6 `2 F) q 1 输入a,n
% v; P, I% h3 P6 e) u$ w 2 resulte = 1 ; 保存逆的结果 1 i P" @ j* b' v u
3 r=n/a+1 ; 保证 r*a>n0 X4 f5 ]4 x {& Z& h* }/ d7 J! _
4 q=r*a-n ; 得到余数,该余数小于a% w0 K! T, H+ r `
5 resulte=(resulte*r)%n & U: X, A8 B+ C t" E
6 if q=1 then print(逆为: resulte) return resulte
6 |) H* d* B( j* X4 Q1 U 7 if q=0 or q=a then print(存在因子: a) return a ;
S8 w! w6 l0 f: t7 q7 T) e 8 a=q
+ M1 L! t6 j) V9 U 9 goto 3+ m( W$ C* C9 Y. N5 {
: {: d( g7 E, V) }1 \ |
zan
|