QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2403|回复: 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
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
    7 S' U1 E6 ~2 a. q! P7 [设 (a,n)=1  (ri,n)=1  (qi,n)=1  1≤i≤m
    / P2 f1 u( N# o$ [4 }  a*r1≡q1 (mod n)& }# W0 h( ~0 e# j$ i6 x
      q1*r2≡q2 (mod n)
    9 Z. l4 E/ v) U8 b# {0 ^  q2*r3≡q3 (mod n)( H  T9 N4 e4 g& {
       .7 b4 ^" A7 o5 X6 D
       .
    0 \0 L0 P# D2 |$ R$ O  .
    " `) q6 o/ Y# X" w* c! @  qm-1*rm≡qm (mod n)
    $ w8 l$ y9 v1 i7 u, ~* m$ ~8 z& i9 l' ^ 上述等式相乘,得:
    3 u0 b/ s2 D6 @; K/ k$ J* M  a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>6 `8 o. m# t" m/ r( f8 ~
      a*(q1*q2*...*qm)≡rm (mod n)
    : V( a$ [! s8 U6 o* x+ n& \  如果对qi(1≤i≤m)进行如下的限定:
    5 W  L7 X& Y, |3 a/ `9 E. a# K7 c9 Z   a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|
    # U$ s1 e3 T8 {( ?5 @" I1 k5 n   则 qm=±1
    : S" D- o3 h8 }. c' `$ f4 i9 T  即 a与q1*q2*...*qm互逆2 T, e3 p8 |: J/ x- f6 z
      例 求28在299的逆
    9 f  K- M- y6 G; y- |9 k4 \* M/ o/ i     28*11≡9 (mod 299)6 f* q" Q* M/ x3 V9 H
         9*33≡-2  (mod 299)
    3 `6 b) U8 m0 S     -2*-150≡1 (mod 299)1 w4 s, |0 ?9 z; O  J: G
      逆为:    11*33*-150≡-32 (mod 299), R  u: `& k& D! g
         28*-22≡-1 (mod 299)
    1 Z0 X% ]( P- Y) ?/ p; c  但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。4 D' m1 Y; S, L! k: E
    下面给出其中一个算法:% P7 o* v* [1 n( {4 i
      1    输入a,n  
    # ]. E; t+ j1 y( @. P  2   resulte = 1   ; 保存逆的结果
    1 r3 M- q0 E' h" ~0 C3 G  3   r=n/a+1      ; 保证 r*a>n( r8 {! }+ _3 S
      4  q=r*a-n       ; 得到余数,该余数小于a
    2 \* u0 T4 c3 w5 r( l9 j4 I) F  5  resulte=(resulte*r)%n   
    2 A) p9 e% z! V3 `+ a  6  if q=1  then  print(逆为: resulte) return  resulte2 G$ m1 V; j6 g5 i  Q& T
      7  if q=0 or q=a then  print(存在因子: a)  return a ;
    9 a0 A0 L! A/ ^5 u: w/ ~' p3 E  8  a=q
    9 U  k9 _; v' L5 V  9  goto 34 }5 ]7 |9 \* r5 }
    6 T$ t& u8 h0 r6 l* t  T- ]

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

    回顶部