• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
ACM s1124yy
守りたいものが 強くさせること
博客园    首页    新随笔    联系   管理     

白书 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。

 

 

 

 

posted @ 2016-07-14 13:33  s1124yy  阅读(174)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3