浅谈逆元 - 逆元的三种解法

作为数论的基础,感觉逆元还是很有用的,基本取模和除法的地方就有它

首先这个东西的定义就是在模 p 意义下,a 乘上自己的逆元等于 1 ,就相当于模 p 意义下的倒数

共三种常用解法,我们今天还是注重一些实践方面,证明的话就略了(绝对不是我忘记了怎么证qwq 。 我们三个方法,各有好坏,也会在最后评述

费马小定理

这个是最简单的,当模数是一个质数 p ,a 关于 p 的逆元就是 \(a ^ {p-2}\) ,就这么轻松愉快

证法比较烦, 大概是构造一个余数集合之类的,个人认为不太重要(?

那么很显然这个可以用快速幂做到 \(O(\log N)\)

优点

  1. 编码极其简单,熟练后可以迅速使用
  2. 单词查询逆元时间复杂度优秀

缺点

  1. 条件苛刻
    需要是一个质数模数,那么出题人毒瘤些整合数模数费马小定理就废了

当然,在大部分综合题里,费马小定理依然是应用场景最广泛的逆元求法

扩展欧几里得算法

这个其实学完扩欧理解很容易,没学过也不难。

扩欧其实只干了一件事,就是求

\[ax + by = \gcd(a,b) \]

这么一个式子,然后像辗转相除一样,利用\(\gcd(a,b) = \gcd(b , a \% b)\)一路递归求一组特解

那么我们可以看问题了,相当于是求模 p 意义下

\[ax \equiv 1 \]

这个是不是直接代入就好了

\[ax = 1 + py \]

p正负无关所以就等于

\[ax + py = 1 \]

求完 x 的特解即为逆元

聪明的小朋友就看出来了,那你这个式子是不是必须得 \(\gcd(a,p) = 1\) 呢?对的对的,也就是求逆元的数要和模数互质

复杂度同欧几里得算法

优点
1.快
2.使用范围比费马小定理更加广泛
只要所求数与模数互质即可,这意味着如果 p 是一个巨大的合数,你就可以用这个求

缺点
1.编码其实不是很简单,代码虽短,如果不背,每次脑子过一遍还是有些麻烦

那么其实单次查询的方法就这俩,都是\(O(\log N)\) 的,如果要一次求一堆逆元呢?

递推

我们可以把模数 p 这样表示

\[p = qx + r \]

那么 $$x \equiv \frac{p - r}{q} \equiv -\frac{r}{q}$$

很显然这个的逆元是\(- \frac{q}{r}\) ,搞一个数组 inv 存逆元,也就是 \((p / x)\times inv_{p \% x}\)

这个挺有趣的,可以放下代码

#include <bits/stdc++.h>
#define ll long long
const int N=3e6+7;
ll n,p; ll a[N];namespace P3811
{	inline void write(int x) {if(x<0)putchar('-'),x=-x;  if(x>9)write(x/10); putchar(x%10+'0');return;   }inline ll read() {int x=0,f=1; char ch=getchar();while(ch<'0'||ch>'9')  {if(ch=='-') {f=-1;}  ch=getchar();}  while(ch>='0' && ch<='9') x=x*10+ch-'0',ch=getchar();  return x*f;}void main(){ n=read(),p=read(); a[1]=1;putchar('1'); putchar('\n');for(register ll i=2;i<=n;i++) {a[i]=(p-p/i)*a[p%i]%p; write(a[i]); putchar('\n');}}
}
int main(){P3811::main();}

即洛谷P3811

复杂度 \(O(N)\)

那么逆元就告一段落了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/898905.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3.14日报

所花时间:8h 代码量(行):220 博客量:6 了解到的知识点: 计算机网络:早上详细讲解了链路层部分,三个基本问题:封装成帧,透明传输,差错检测。 其中着重讲解了有关计算的二进制序列,随堂练习更是一半的计算 然后就是下午的软件测试 要做一个地铁售票

使用fastapi部署网页模板

背景 如果你想快速实现一个网站的前后端的部署,那么现成的站点模板是必须的,如果我们使用nginx做反向代理可以实现部署静态网站,如果我想相对请求或者页面有一些更新,那么就需要用到后端框架,这里我们使用fastapi去代理静态资源同时将模板的请求根据我们的需求进行动态的返…

第四周第五天

所用时间:270分钟 代码量(行):174 博客量(篇):1 了解到的知识点: 1.课堂测试 编写了简单的地铁购票系统app,实现了按站计算购票费用,将项目打包为apk后再手机端运行成功 学习了如何将项目打包为apk文件,如下图所示2.计算机网络

Apache Tomcat RCE漏洞复现(CVE-2025-24813)

今日官方披露 Apache Tomcat partial PUT文件上传反序列化漏洞。在 CVE-2025-24813 中tomcat开启文件会话持久化,攻击者可利用PUT上传文件,并构造恶意请求触发session文件反序列化。漏洞描述 该漏洞的核心在于不完整PUT请求上传时 Tomcat 会使用了一个基于用户提供的文件名和…

SparkSubmit提交任务到yarn及报错解决方案

SparkSubmit提交任务到yarn及报错解决方案@目录一、提交任务代码二、Linux提交可能出现的问题及解决方案情况1:JSON解析异常情况2:java.lang.InstantiationException spark.sql.driver情况3 中kafka:java.lang.NoClassDefFoundError: org/apache/kafka/clients/producer/Cal…

线程异步处理任务

实际开发中,service层可能会执行多个步骤,那有些步骤可能和主任务没有太大关联,那我们可以采用线程去处理,这样就提高响应速度,当然也可以采用MQ,此处介绍的是用线程处理 1、controller层@GetMapping("/thread")public void thread(){demo1Service.process();}…

08. 通用定时器

一、什么是通用定时器ESP32 S3 芯片配备了两个通用定时器组,每组均包含两个通用定时器和一个主系统看门狗定时器。每个通用定时器都具备多个通道。通过明确指定定时器号和通道号,用户可以精准地选定所需的定时器和通道。每个定时器均支持独立编程,并且具备微秒级的精确时间中…

全链路赋能游戏鸿蒙化适配,鸿蒙游戏开发者服务焕新升级

3月14日,华为游戏中心在成都开展了鸿蒙游戏开发者服务日线下活动。本次活动吸引了百余位游戏厂商代表以及开发者参与。华为一线技术专家团队与众多游戏开发者进行了面对面的深入交流,聚焦游戏鸿蒙化全流程技术实践,通过专家授课、案例解析与现场互动,为开发者提供从技术适配…

多线程程序设计(三)——Guarded Suspension

本文摘要了《Java多线程设计模式》一书中提及的 Guarded Suspension 模式的适用场景,并针对书中例子(若干名称有微调)给出一份 C++ 参考实现及其 UML 逻辑图,也列出与之相关的模式。 ◆ 适用场景 当线程访问的共享数据没有准备好时,让该线程进入等待状态,直到数据被准备好…

西部数据企业级硬盘HC310开盘数据恢复,300G左右数据量耗时半年

这块西数4T企业级硬盘HC310是杭州某研究所送过来的,突发损坏不识别,通电后咯吱咯吱敲盘异响,磁头坏了。这款企业级硬盘目前开盘成功率一般,因为磁头适配很困难,需要反复更换磁头,备件成本很高。这种硬盘的开盘难度跟服务器SCSI或SAS硬盘有的一拼,没有经验甚至拆一个废一…

5分钟,构建国产数据库智能体

近期,圈里很多朋友,都尝试利用 DeepSeek 构建自己的智能体。我也利用腾讯元器,将个人公众号内容做了个智能体,可以实现简单的问答。那么延展来看,智能体除了可利用公众号内容,也可使用离线文件等方式来构建。这不禁让我考虑,是否可用这样方式构造一个数据库智能体。说干…

Ubuntu 22.04 LTS 基于 Docker 部署 WordPress

Ubuntu 22.04 LTS 基于 Docker 部署 WordPress 1. 引言 WordPress 是全球最受欢迎的内容管理系统 (CMS),使用 Docker 可以简化其部署过程。本教程将介绍如何在 Ubuntu 22.04 LTS 上使用 Docker 部署 WordPress。2. WordPress 简介 2.1 WordPress 是什么? WordPress 是全球最流…