数学中国

 找回密码
 注册
搜索
热搜: 活动 交友 discuz
查看: 847|回复: 0

一个乘法逆元的计算方法

[复制链接]
发表于 2023-11-19 15:54 | 显示全部楼层 |阅读模式
    一个乘法逆元的计算方法

以下给出一个求乘法逆元的方法,主要是使用除数的积来求逆,供大家参考,如有不足,欢迎大家批评指正。
设 (a,n)=1  (ri,n)=1  (qi,n)=1  1≤i≤m
  a*r1≡q1 (mod n)
  q1*r2≡q2 (mod n)
  q2*r3≡q3 (mod n)
   .
   .
  .
  qm-1*rm≡qm (mod n)
上述等式相乘,得:
  a*(r1*r2*...*rm-1)*(q1*q2*...*qm)≡r1*r2*...*rm-1*rm (mod n) =>
  a*(q1*q2*...*qm)≡rm (mod n)
  如果对qi(1≤i≤m)进行如下的限定:
   a>|q1|>|q2|>...>|qi|>...>|qm-1|>|qm|
   则 qm=±1
  即 a与q1*q2*...*qm互逆
  例 求28在299的逆
     28*11≡9 (mod 299)
     9*33≡-2  (mod 299)
     -2*-150≡1 (mod 299)
  逆为:    11*33*-150≡-32 (mod 299)
     28*-22≡-1 (mod 299)
  但该方法有个最大的问题,当(qi,n)>1时,该方法将无法继续往下计算逆。

下面给出其中一个算法:
  1    输入a,n  
  2   resulte = 1   ; 保存逆的结果
  3   r=n/a+1      ; 保证 r*a>n
  4  q=r*a-n       ; 得到余数,该余数小于a
  5  resulte=(resulte*r)%n   
  6  if q=1  then  print(逆为: resulte) return  resulte
  7  if q=0 or q=a then  print(存在因子: a)  return a ;
  8  a=q
  9  goto 3

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|数学中国 ( 京ICP备05040119号 )

GMT+8, 2024-7-18 04:39 , Processed in 0.062500 second(s), 16 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表