逆元的意义与求解

1.什么是逆元

当求解公式:(a / b) % m 时,因b可能会过大,会出现爆精度的情况,所以需变除法为乘法:

cb的逆元,则有b * c≡1(mod m);

(a / b) % m = (a / b) * 1 % m = (a / b) * b * c % m = a * c( mod  m);

a / b的模等于a * b的逆元的模;

逆元就是这样应用的;

 

2.求逆元的方法

(1)费马小定理

在是素数的情况下,对任意整数都有。 
如果无法被整除,则有。 
可以在为素数的情况下求出一个数的逆元,,即为逆元。

结果得出,x ^ (mod - 2) 即为x的逆元

(2)O(n)逆元打表

void init()
{
    inv[1] = inv[0] = 1;
    for (LL i = 2; i < maxn; i++)
        inv[i] = (mod - mod / i) * inv[mod % i] % mod;
}

inv数组内即为逆元;

 

OVER!

 

参考博客:

https://blog.csdn.net/baidu_35643793/article/details/75268911#

https://blog.csdn.net/b_r_e_a_d/article/details/81431506

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值