QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2117|回复: 0
打印 上一主题 下一主题

一个乘法逆元的计算方法

[复制链接]
字体大小: 正常 放大
songls        

6

主题

3

听众

23

积分

升级  18.95%

  • TA的每日心情
    郁闷
    2023-12-11 09:00
  • 签到天数: 7 天

    [LV.3]偶尔看看II

    跳转到指定楼层
    1#
    发表于 2023-12-10 20:02 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
      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

    一个求乘法逆元的方法.pdf

    39.85 KB, 下载次数: 0, 下载积分: 体力 -2 点

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-11-7 09:00 , Processed in 0.942962 second(s), 53 queries .

    回顶部