- 在线时间
- 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
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。" m0 `' y% y3 B7 w7 c! R
设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m( u6 E, {" D$ U$ C% J/ l4 Q( p r
a*r1≡q1 (mod n)0 ]% p' T1 h2 S
q1*r2≡q2 (mod n) A0 ^3 W- |0 s' L) r- C
q2*r3≡q3 (mod n)* V3 n2 \# F+ R2 J) `
.9 O R# R; C. C, S# r+ a' C$ I
.& X- g7 k6 q* |/ H2 f6 y
.# q5 T+ h+ n1 [ G# R
qm-1*rm≡qm (mod n)$ r' O5 P" Y& D
上述等式相乘,得:" c, c3 R0 g. [- F
a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>, J/ S8 h/ Y# H! C
a*(q1*q2*...*qm)≡rm (mod n)
+ G ~. ~" O: ` 如果对qi(1≤i≤m)进行如下的限定:
0 k3 a2 k& o% M% X# f0 z8 y4 Z a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|0 X% j/ m Z& A) Q6 E' R
则 qm=±1
' G, t( r3 f ~# t 即 a与q1*q2*...*qm互逆 H. ]$ ]: r/ O, J. g3 o
例 求28在299的逆
, j1 W8 K3 `8 i$ M( L 28*11≡9 (mod 299)% l! Q3 T- Q, s; p9 o0 j
9*33≡-2 (mod 299)6 D) i! c# E6 x3 [/ ~
-2*-150≡1 (mod 299)# m' C9 L/ ]8 E, n8 L% R
逆为: 11*33*-150≡-32 (mod 299)) P7 R, r# g2 N
28*-22≡-1 (mod 299)4 [+ `" P4 s u
但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
4 T+ a5 J8 g$ k% J6 Z9 V5 y% B 下面给出其中一个算法:) Z* W0 V. i& \+ ?; N- T+ a
1 输入a,n
' E( W! Q/ X9 d) e# R/ `1 E 2 resulte = 1 ; 保存逆的结果
' u: s# V8 ?+ G2 f2 C: Q. i" r 3 r=n/a+1 ; 保证 r*a>n; N! t/ D& D2 v. m/ O1 b- B% M7 i/ _" D
4 q=r*a-n ; 得到余数,该余数小于a
! X- h! D h8 W5 V 5 resulte=(resulte*r)%n # q7 c6 X- R$ Q+ B) d, b
6 if q=1 then print(逆为: resulte) return resulte, X# ^) b. c1 h
7 if q=0 or q=a then print(存在因子: a) return a ;
9 {6 w2 k% Y( Z# Z1 L1 ` 8 a=q
- a) L6 P, C# C: T% i" _ 9 goto 39 j! }5 X' m0 U. }- u$ z
1 w5 U( R& q _# s+ a
|
zan
|