O(n)求逆元

本文通过简单的数学推导,介绍了如何在模p意义下找到一个数的逆元。首先从同余方程出发,通过一系列转换,最终得出逆元的计算公式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

本文主要是写给自己看的因为实在是太简单了但还是记不住啊

推导

求x在模p意义下的逆元

首先有(这里的模数是x)
p≡y (mod x)p\equiv y\,(mod\,x)py(modx)
显然可以得到
p−⌊px⌋x=yp-\left \lfloor \frac{p}{x}\right \rfloor x=ypxpx=y
然后转回同余方程(注意这里的模数变成了p)
−⌊px⌋x≡y (mod p)-\left \lfloor \frac{p}{x}\right \rfloor x\equiv y\,(mod\,p)xpxy(modp)
交换一下xy的位置
−⌊px⌋y−1≡x−1 (mod p)-\left \lfloor \frac{p}{x}\right \rfloor y^{-1}\equiv x^{-1}\,(mod\,p)xpy1x1(modp)
x−1≡−⌊px⌋y−1 (mod p)x^{-1}\equiv -\left \lfloor \frac{p}{x}\right \rfloor y^{-1}\,(mod\,p)x1xpy1(modp)


好吧用人话再写一遍
p mod x=y
p-(p/x)*x=y (注意这里的除是整除)
-(p/x)*x mod p=y
-(p/x)*y-1 mod p=x-1
x-1=-(p/x)*y-1 mod p

因为y=p mod x<x,所以可以顺推

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值