费马小定理求逆元 以及求逆元广泛式子总结

费马小定理(Fermat Theory)算法

假如p是质数,且(a,p)=1,那么 a(p-1)≡1(mod p)。即:假如a是整数,p是质数,且a,p互质(即二者只有一个公约数1),那么a的(p-1)次方除以p的余数恒等于1。函数

 

当涉及取模运算的计算中,若是有除法,不能直接除以一个数,而应该变成乘以它的乘法逆元ui

当咱们除以一个数n时,也就是乘上1/n,若x是1/n关于模N的逆元,则x=1/n (mod N),即 x*n=1(mod N)。因为咱们作题时N经常为1000000007,而1000000007是个素数,spa

因此它知足了费马小定理,而知足费马小定理说明解惟一,因此咱们能够直接得出x*n=n^(N-1)。那么x=n^(N-2),即为1/n关于模N的乘法逆元code

 

求出乘法逆元 (快速幂处理) a^borm

 1 ll quickmod(ll a,ll b)
 2 {
 3     ll sum=1;
 4     while(b)
 5     {
 6         if(b&1)
 7             sum=(sum*a)%mod;
 8         b>>=1;
 9         a=(a*a)%mod;
10     }
11     return sum;
12 }

 

拓展欧几里得htm

扩展欧几里德算法是用来在已知a, b求解一组x,y,使它们知足贝祖等式: ax+by = gcd(a, b) =d(解必定存在,根据数论中的相关定理)。扩展欧几里德经常使用在求解模线性方程及方程组中blog

扩展欧几里得。aa^-1≡ 1(mod p),能够转换为aa^-1 + py = 1,便是扩展欧几里得所能解的ax + by = gcd(a, b)。最经常使用的解法。get

 1 int x, y;
 2 int extgcd(int a, int b, int &x, int &y)
 3 {
 4     if (b == 0){
 5         x = 1;
 6         y = 0;
 7         return a;
 8     }
 9     int gcd = exgcd(b, a % b, x, y);
10     int tmp = x;
11     x = y;
12     y = tmp - (a/b) * y;
13     return gcd;
14 }
15 
16 /*
17 求解ax+by=gcd(a,b),亦即ax≡1(mod b)。函数返回值是a,b的最大公约数,而x即a的逆元。
18 注意a, b不能写反了。
19 */

 

*******class

可是你会发现费马小定理和扩展欧几里得算法求逆元是有局限性的,它们都会要求互素。实际上咱们还有一

种通用的求逆元方法,适合全部状况。公式以下

 

         

 

如今咱们来证实它,已知,证实步骤以下

 

         

m*b若是爆int 须要使用快速幂

相关文章
相关标签/搜索