O(N) 的时间求 1 - N 关于 MOD 的逆元

新学的一个求逆元的方法:

inv[i] = ( MOD - MOD / i ) * inv[MOD%i] % MOD

证明:

设t = MOD / i , k = MOD % i

则有 t * i + k == 0 % MOD

有 -t * i == k % MOD

两边同时除以ik得到

-t * inv[k] == inv[i] % MOD

inv[i] == -MOD / i * inv[MOD%i]

inv[i] == ( MOD - MOD / i) * inv[MOD%i]

证毕

适用于MOD是质数的情况,能够O(n)时间求出1~n对模MOD的逆

迭代初始化 inv[1] = 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用C语言设明文字母表为:p={p0,p1,…,pn-1}密文字母表:c={c0,c1,…,cn-1} 引入两个参数 a、b,要a和n互素,即gcd(a,n)=1;加密算法:ci=E(Pi)=(a*pi+b)modn在解密时,首先需解a在有限域Zn上的乘法元a-1∈Zn,可用欧几里得算法解;解密算法:pi=D(ci)=a-1(ci-b)modn(1)取明文空间和密文空间为26个英文字母表,其大小为n=26;(2)出集合{0,1,2,3,…,25}中所有与26互素的数,并从中任取一个,作为a。另外,任取b∈{0,1,2,3,…,25};输出a和b;(3)出a在有限域Zn上的乘法元a-1∈Zn;(4)从键盘输入一个字符串,长度约为15字符。然后按照a b c d e f g h i j k l m n o p q r s t u v w x y z分别对应0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25的方式,将明文转换为数字序列(不区分大小写,并忽略空格);(5)对第(4)步得到的数字序列逐数字加密,得到密文数字序列;(6)按照第(4)步中的映射方式,将第(5)步得到的数字序列映射为字母序列(即密文),并输出密文;(7)按照第(4)步中的映射方式,将第(6)步得到的密文序列映射为数字序列;(8)按照解密算法,对第(7)步得到的数字序列逐数字解密,得到明文数字序列;(9)按照第(4)步中的映射方式,将第(8)步得到的数字序列映射为字母序列(即明文),并输出。
最新发布
05-10
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值