QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1824|回复: 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
    以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。! u% ]7 ^( Q2 _* g
    设 (a,n)=1  (ri,n)=1  (qi,n)=1  1≤i≤m5 u# c; Y  }0 N1 ^1 a4 ~; Q
      a*r1≡q1 (mod n)* j( ^- v/ R/ p+ M/ L: I4 ~) `0 D
      q1*r2≡q2 (mod n)! ]9 y6 D, T4 z3 [- S
      q2*r3≡q3 (mod n)
    $ T1 l# h' A4 R4 U+ i+ Q   .( E5 Q6 {6 _" V' y, d6 ^0 e
       .7 ?, ^2 x) y  a: ?2 J$ w2 a3 C( w
      .
    9 u1 Z* S7 x% K& T4 Q+ w  qm-1*rm≡qm (mod n)
    , b& T* u# S1 M: I9 a 上述等式相乘,得:4 c0 ]4 `+ w( l) D
      a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>5 g- F; Y/ h4 m' l
      a*(q1*q2*...*qm)≡rm (mod n) - w. X: `' ?* f  u& y, h
      如果对qi(1≤i≤m)进行如下的限定:
    ' ]8 x# \4 S/ v* ]; }  q   a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|5 z: }* t7 k) U' W
       则 qm=±13 y4 L* R6 T+ b
      即 a与q1*q2*...*qm互逆
    * |# Y* i! U$ j" {  d, l  例 求28在299的逆
    / U. X3 O. O) _: ~' {/ O5 R' z     28*11≡9 (mod 299)' g) r* {, E2 q) a( m1 d$ K7 }
         9*33≡-2  (mod 299)% G! x  U5 A  g4 F) U% g
         -2*-150≡1 (mod 299)$ \3 j3 f+ p0 S3 a$ O/ u
      逆为:    11*33*-150≡-32 (mod 299)
      v. R; y# r8 j; \: U2 ?     28*-22≡-1 (mod 299)
    3 P) N) H+ }1 _# e  但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。# {/ B% Z/ L$ `: R
    下面给出其中一个算法:
    3 L$ n# h" z" t3 s  1    输入a,n  
    ' R; t& i+ C: q  S  2   resulte = 1   ; 保存逆的结果
    / u4 s+ C. _9 T; U5 g! N: _  3   r=n/a+1      ; 保证 r*a>n
    7 p: C7 u# F! _& V5 Z4 i  4  q=r*a-n       ; 得到余数,该余数小于a3 x$ e0 A3 D) [) C. n* j4 `
      5  resulte=(resulte*r)%n   
    ) r' R' O' C5 D1 ^% c3 v" H  6  if q=1  then  print(逆为: resulte) return  resulte# \* b7 R; s+ c  y4 s" k8 |& w* Q
      7  if q=0 or q=a then  print(存在因子: a)  return a ;
    " _* |6 I# j* h$ @7 V  8  a=q1 E% X2 g/ s$ D0 b2 B1 S
      9  goto 3
    9 z* ^* ]$ z* K2 J
    ( F3 j& D$ A7 h) W+ {: R

    一个求乘法逆元的方法.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-7-10 08:09 , Processed in 0.308214 second(s), 53 queries .

    回顶部