数学模板-逆元

逆元

因为mod不满足除法,所以我们需要用到逆元来求a/b的模数。逆元就相当与(1/b)mod p
逆元有两种求法。第一种就是用扩展欧几里德来求解。
我们有同余方程

ax1(modp)

如果有解,x就算a模p意义下的逆元。
可以变成
axyp=1

用扩展欧几里德来求解。

线性筛逆元
其实还有线性的方法筛出**质素**p的逆元。
我们设

111(modp)

p=xa+r,r<a,1<i<p
有我们知道
p0(modp)=>xa+r0(modp)

两边同时乘以 a1r1 得到
xr1+a10(modp)

整理得
a1xr1(modp)

a1pa(pmoda)1(modp)

代码

a[1]=1;
for(int i=2;i<p;i++)
    a[i]=-(p/i)*a[p%i];
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值