QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2400|回复: 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
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。1 Q4 h% L5 W& F; p- w3 ]. b( L
    设 (a,n)=1  (ri,n)=1  (qi,n)=1  1≤i≤m
    ; j, I7 R4 S3 H; z5 E9 d" s( A  a*r1≡q1 (mod n)* O8 |, L8 l, _
      q1*r2≡q2 (mod n)) |' p" p; z# g
      q2*r3≡q3 (mod n)
    # f+ r, G) J' i! X   .: R! g1 V, f' E3 u  a1 g
       .
    * r1 g) B6 q6 u  .
    - [$ V& q* m, i7 K  ^$ `  qm-1*rm≡qm (mod n)1 o$ u0 m* P" b  W9 _  W( J* z
    上述等式相乘,得:" W7 s6 T# c, Y$ z) {$ t
      a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>& T* w' C' H, @% ]8 f8 ^3 k
      a*(q1*q2*...*qm)≡rm (mod n) , n( U6 R; d! U) x1 [- T( x" u' R5 ~
      如果对qi(1≤i≤m)进行如下的限定:4 Z: s4 T! D  w. w0 F
       a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|7 z6 U) R4 L1 s
       则 qm=±1* m( y! ^7 M2 q" X% i
      即 a与q1*q2*...*qm互逆. l6 t" F- c( g4 ^! `
      例 求28在299的逆
    ( x/ U' C0 ?8 c" W     28*11≡9 (mod 299): j$ Y- K2 }' \
         9*33≡-2  (mod 299)
    ( S! \* k: F+ V/ _0 B     -2*-150≡1 (mod 299), q' D4 j6 h9 U" W3 A9 s
      逆为:    11*33*-150≡-32 (mod 299)
    - A2 n- a% ?, r4 Q7 m' F9 r     28*-22≡-1 (mod 299); O9 `; V2 }9 O+ q4 C+ r
      但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。
    . k1 P# p1 o) J2 ~+ e  s 下面给出其中一个算法:/ L  y1 O& N0 e4 X9 q
      1    输入a,n  + L% I, \4 [# ^: o) a4 z* z
      2   resulte = 1   ; 保存逆的结果
    - a6 q$ ?# M2 O  3   r=n/a+1      ; 保证 r*a>n
    ( ~) u" |+ x/ Y, o7 S, }  4  q=r*a-n       ; 得到余数,该余数小于a
    # f2 z$ X' `% Y1 m: o! D$ k; ~  5  resulte=(resulte*r)%n   
    7 x5 o0 X4 Y8 T  6  if q=1  then  print(逆为: resulte) return  resulte/ j2 g5 w6 v% A. @( q+ S. T& Q, E; g
      7  if q=0 or q=a then  print(存在因子: a)  return a ;; z  x# l" p0 d3 q2 @7 [) q! ~, r
      8  a=q
    9 R2 E+ m1 L6 `+ u/ T; _$ y  9  goto 3
    : {# Q9 [) Z; P' {( c' z3 ~( e/ {9 T! W4 O* I

    一个求乘法逆元的方法.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, 2026-4-14 02:56 , Processed in 0.288456 second(s), 52 queries .

    回顶部