- 在线时间
- 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
 |
以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。3 G3 T( @' F. \* }6 l6 ?" q
设 (a,n)=1 (ri,n)=1 (qi,n)=1 1≤i≤m2 J+ P+ \/ Z8 d
a*r1≡q1 (mod n)' @2 [1 c* f3 ?" L+ K+ D
q1*r2≡q2 (mod n)
/ l2 t7 R! R+ D+ U9 Y. t q2*r3≡q3 (mod n)
8 ~" L f4 X# g& D6 {- G% W4 b .. G' j, W8 X; K
.
8 d/ F$ ?7 G+ q7 I$ x .
$ E/ u5 J7 Q: Z8 p- w qm-1*rm≡qm (mod n)
' o* A+ x6 `& `/ I 上述等式相乘,得:
8 p* v& w7 [# O& x+ y" |" k a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>
# E) S6 v0 \: v& ?" c4 A7 @ a*(q1*q2*...*qm)≡rm (mod n) 5 p& ?" t* l' e% L3 m' x
如果对qi(1≤i≤m)进行如下的限定:+ C& L" d, q. I; w8 X) K: l- k' [# z
a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|9 T6 v# e8 H! B, J+ v3 T# u- H
则 qm=±1
0 G# k* f4 f7 I& X& K% i 即 a与q1*q2*...*qm互逆5 S9 u, E4 p" X; B
例 求28在299的逆
* k5 Q0 |+ [/ s& I( U- x( }( I* m 28*11≡9 (mod 299)0 v7 C& O+ Y- k/ V/ F
9*33≡-2 (mod 299)
: |' @% y. q( w$ p4 `) i# S -2*-150≡1 (mod 299)
i/ w! ]; C R. m/ L9 a 逆为: 11*33*-150≡-32 (mod 299)
3 Y& A$ P) ^7 x9 l' p+ U6 b; y 28*-22≡-1 (mod 299)
% x# u) ~( s/ p0 |0 d 但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
) W% C" `! [7 w1 o- @, j8 ^ 下面给出其中一个算法:- x$ G- T2 ]: i
1 输入a,n
9 Y D( F/ u; X0 \ 2 resulte = 1 ; 保存逆的结果
; [) N' l3 f. H+ T: L 3 r=n/a+1 ; 保证 r*a>n
# F: Y) S: X( W/ P0 P 4 q=r*a-n ; 得到余数,该余数小于a
( ?4 e1 |9 ` ~, P! N# Y 5 resulte=(resulte*r)%n
. Y/ c( b, _9 c6 o7 b" | 6 if q=1 then print(逆为: resulte) return resulte' A) e# G; q5 ^
7 if q=0 or q=a then print(存在因子: a) return a ;: \ f' j2 V( Y( b# T
8 a=q
# u, m2 w! R" C' c- J 9 goto 3* v) H+ E9 E. O! w( r0 C
5 a$ _) X+ D" i' j9 k |
zan
|