- 在线时间
- 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
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。. o' o+ X. j3 O% K
设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m
- q# y/ ]: g( L- b7 N a*r1≡q1 (mod n)" W. u+ ?5 e+ P% o
q1*r2≡q2 (mod n)2 P1 b* }2 ~0 Q- }# _* |" S! k
q2*r3≡q3 (mod n)5 M' F4 T6 Q A) g" U4 o
.
& A, y& F( M( K8 O4 c .4 O1 j( l! X& S' Y" {/ a
.8 x# ?7 x3 n6 a; A0 }3 w
qm-1*rm≡qm (mod n)# E1 Q; {' M7 a0 [) }" c0 X
上述等式相乘,得:
" h( V' H" t2 I a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>* S$ v8 _7 b! v; k7 I
a*(q1*q2*...*qm)≡rm (mod n)
. U6 A! B: ^7 Y/ g% o3 p# j% D 如果对qi(1≤i≤m)进行如下的限定:
- r/ h- p1 Z, S& Q a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|
5 a: {* r' s* c z 则 qm=±15 A5 u1 g" @# b% J
即 a与q1*q2*...*qm互逆( ~1 O8 e$ j' \0 h, ?
例 求28在299的逆7 C% ?0 ~7 L1 u I
28*11≡9 (mod 299)
8 L. Q% J! R6 f7 {7 _ 9*33≡-2 (mod 299), j9 B. E2 m. T: c
-2*-150≡1 (mod 299)2 u; w1 ? g, H
逆为: 11*33*-150≡-32 (mod 299), m& }: l, x/ m I+ b
28*-22≡-1 (mod 299)
/ a0 t9 M4 ^1 B8 d 但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
+ ]* W5 ?) i: g 下面给出其中一个算法:
1 h, ~8 ]/ j4 p) c$ C 1 输入a,n
7 X% O7 r6 s Q1 f 2 resulte = 1 ; 保存逆的结果 7 E. d% q& @+ c$ w+ e( x! n R8 [
3 r=n/a+1 ; 保证 r*a>n9 S, I# U R) |, m) Q8 i( O
4 q=r*a-n ; 得到余数,该余数小于a
% K; | S1 V' [1 i% N2 J. D 5 resulte=(resulte*r)%n
1 {8 n8 u2 u9 s1 m: i! D, r! F7 M 6 if q=1 then print(逆为: resulte) return resulte
( A# c! {* l j; i 7 if q=0 or q=a then print(存在因子: a) return a ;+ r3 G$ Q& H, u0 y+ i7 h6 @3 q# x
8 a=q8 G6 m! e7 P ~* J6 q( |
9 goto 36 b7 S9 K$ z8 g' L. B8 k# m; `. }
; E" o' q, P5 ~8 d
|
zan
|