QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2120|回复: 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
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。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

    一个求乘法逆元的方法.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 19:28 , Processed in 0.380402 second(s), 58 queries .

    回顶部