QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1952|回复: 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
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
    & _6 R* F7 [4 t设 (a,n)=1  (ri,n)=1  (qi,n)=1  1≤i≤m
    4 Z3 z! R. C' d6 C  a*r1≡q1 (mod n)
    4 {+ i( n7 s; P2 k# V/ G: Y. E8 M0 f  q1*r2≡q2 (mod n)
    ' }6 |8 `5 M- s) T0 P" T  q2*r3≡q3 (mod n)
    7 I, l, ]. ~4 }, o5 u/ l! X9 P- ]   .$ t1 }3 I5 b, [6 b
       .
    $ g! ]7 U% M& Q+ b& N  l2 l  .' o. l0 b5 \# o" G
      qm-1*rm≡qm (mod n)3 c2 v2 N; M8 r) `5 a
    上述等式相乘,得:& {9 A% b6 R3 v4 h* F! R
      a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>
    ! d8 @! `# R& u- u7 g6 @  a*(q1*q2*...*qm)≡rm (mod n) ; Z4 h5 R/ V9 `% h2 ?' r' h
      如果对qi(1≤i≤m)进行如下的限定:
    & I3 Q" f% D- y. b   a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|
    ! V+ A$ q) ~# n/ Y  R$ T' ~   则 qm=±15 c/ P- V9 n- `: t4 W
      即 a与q1*q2*...*qm互逆
    3 [6 R5 k% A/ L0 Q  f4 G& m  例 求28在299的逆, o  B/ Y* G9 Y0 A- z) _6 Q  t
         28*11≡9 (mod 299)
      z" R8 b# L2 n/ k4 H     9*33≡-2  (mod 299): Y7 X0 m! ^2 @
         -2*-150≡1 (mod 299)
    ! T7 `4 U0 k; h- e  逆为:    11*33*-150≡-32 (mod 299)
    % ^+ F% Q/ j5 ?+ h5 i" S- }     28*-22≡-1 (mod 299)
    - D; Z4 ~6 g' x/ R  但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
    4 h- r2 X9 H/ E# }, _/ y 下面给出其中一个算法:' ]3 T# k* X: {( n0 K* j; P
      1    输入a,n    j; t0 q: x, [, y
      2   resulte = 1   ; 保存逆的结果 2 v/ k9 m0 d  k3 u0 T
      3   r=n/a+1      ; 保证 r*a>n# r+ V# ~8 p4 s1 O2 w
      4  q=r*a-n       ; 得到余数,该余数小于a
    " c& v( B8 L8 j$ ~7 k  p  5  resulte=(resulte*r)%n   
    5 `: u/ U9 k( S% V  6  if q=1  then  print(逆为: resulte) return  resulte. ]  G6 Q* I0 `1 ?" f- \" l$ r% v% W
      7  if q=0 or q=a then  print(存在因子: a)  return a ;
    " n7 L5 x2 b" H) K" R  8  a=q7 P# O' l! e2 L% x
      9  goto 3
    % E3 l, r7 C; A8 k9 d8 e4 V
    1 O  O% ]- z1 l7 W# {* W

    一个求乘法逆元的方法.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-8-8 03:55 , Processed in 0.366288 second(s), 52 queries .

    回顶部