博客
关于我
学习逆元
阅读量:153 次
发布时间:2019-02-27

本文共 868 字,大约阅读时间需要 2 分钟。

模逆元是模运算中的一个重要概念,常用于解决在模运算中除法运算的问题。模逆元的定义是:对于正整数a和模p,如果存在一个正整数b,使得a*b ≡ 1 (mod p),那么b称为a在模p下的乘法逆元,或者说a在模p下的逆元。

存在性

模逆元的存在性依赖于a和p是否互质。根据数论中的贝祖定理,如果a和p的最大公约数gcd(a, p) = 1,那么在模p意义下,a存在一个逆元。如果a和p不互质,那么a在模p下是没有逆元的。这是因为如果a和p有共同因子d > 1,那么a*b ≡ 1 (mod p)意味着d也必须整除1,这是不可能的。

求法

求模逆元有多种方法,主要有以下几种:

  • 扩展欧几里得算法:扩展欧几里得算法是一种强大的工具,可以用来求解线性同余方程ax + by = gcd(a, b)。在求模逆元时,可以将问题转化为求解ax ≡ 1 (mod p)。通过扩展欧几里得算法,可以找到满足该方程的x值,这个x值就是a在模p下的逆元。

  • 线性求逆元:这种方法基于以下观察:在模p意义下,p可以表示为a*q + r,其中r是p对a取模的结果。通过递推和变换,可以找到逆元。这种方法适用于所有情况,但计算量可能较大。

  • 欧拉定理:当p是质数时,欧拉定理可以简化求逆元的过程。根据欧拉定理,如果a和p互质,那么a^(p-1) ≡ 1 (mod p)。因此,a的逆元可以通过计算a^(p-2) mod p得到。

  • 应用

    模逆元在密码学和算法中有广泛的应用。例如,在计算(a/b) mod p时,可以通过求b的逆元k来转化为(a*k) mod p,这样可以避免直接进行除法运算,提高计算效率和安全性。

    个人理解

    模逆元的本质在于将除法转化为乘法,使得在模运算中可以方便地进行除法运算。例如,在模7意义下,3的逆元是5,因为3*5 = 15 ≡ 1 (mod 7)。这种转换在处理大数时尤为重要,因为直接计算逆元可以避免处理大数除法带来的效率问题。

    总之,模逆元是模运算中的一个重要工具,能够将复杂的除法问题转化为简单的乘法问题,极大地简化了许多算法的实现。

    转载地址:http://mtib.baihongyu.com/

    你可能感兴趣的文章
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    PHP $_SERVER['HTTP_REFERER'] 获取前一页面的 URL 地址
    查看>>
    php & 和 & (主要是url 问题)
    查看>>
    php -- 魔术方法 之 判断属性是否存在或为空:__isset()
    查看>>
    php -- 魔术方法 之 获取属性:__get()
    查看>>
    php -树-二叉树的实现
    查看>>
    PHP -算法-二路归并
    查看>>
    php 2条不一样 的json数据 怎么放在一个json里面_如果你是PHP开发者,请务必了解一下Composer...
    查看>>
    php 360 不记住密码,JavaScript_多种方法实现360浏览器下禁止自动填写用户名密码,目前开发一个项目遇到一个很 - phpStudy...
    查看>>
    regExp的match、exec、test区别
    查看>>
    php 404 自定义,APACHE 自定义404错误页面设置方法
    查看>>
    PHP 5.3.0以上推荐使用mysqlnd驱动
    查看>>
    php 7.2 安装 mcrypt 扩展: mcrypt 扩展从 php 7.1.0 开始废弃;自 php 7.2.0 起,会移到 pecl...
    查看>>
    php aes sha1解密,PHP AES加密/解密
    查看>>
    php CI框架单个file表单多文件上传例子
    查看>>
    php composer
    查看>>
    reflow和repaint引发的性能问题
    查看>>
    php csv 导出
    查看>>
    php curl 实例+详解
    查看>>