白书 4.1.2 模运算的世界 P291

本文详细介绍了逆元的概念及其实现方法,并通过扩展欧几里得算法求解逆元。此外,还讲解了费马小定理及其在求逆元中的应用条件,即当模数为素数时的特殊情况。

  1.逆元

  这里有个注意事项要说,就是当要求 (a-b)%m 的时候要注意不能直接 (a%m-b%m)%m 原因是得出的值有可能是负数,所以 (a%m-b%m+m)%m 才是正确的。

//x,y是引用
int exgcd(int a,int b,int &x,int &y){
    //d是最后要返回的
    int d=a;
    if (b!=0){
        //递归时,y和x也要换
        d=exgcd(b,a%b,y,x);
        //根据x求y
        y-=(a/b)*x;
    }else{
        x=1;y=0;
    }
    return d;
}

//求逆元 ax恒等于1(mod m)
int mod_inverse(int a,int m){
    int x,y;
    exgcd(a,m,x,y);
    return (m+x%m)%m;
}

  2.费马小定理

  这里说的简单点,它就是能简单的求逆元,但有限制条件,就是只有m是素数的时候才可以用。

  即当m是素数时,ax恒等于1(mod m),这时a的逆等于a的m-2次方模m。

 

 

 

 

转载于:https://www.cnblogs.com/s1124yy/p/5670135.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值