【数学】简化剩余系、欧拉函数、欧拉定理与扩展欧拉定理

简化剩余系

与完全剩余系略有区别。
我们定义数组 a i ( 1 ≤ i ≤ n ) a_i(1\le i\le n) ai(1in) 为模 m m m 的简化剩余系,当且仅当 ∀ 1 ≤ i , j ≤ n \forall 1\le i,j\le n ∀1i,jn,有 a i ≢ a j ( m o d m ) a_i\not\equiv a_j\pmod m aiaj(modm) ∀ 1 ≤ i ≤ n \forall 1\le i\le n ∀1in,有 gcd ⁡ ( m , a i ) = 1 \gcd(m,a_i)=1 gcd(m,ai)=1

  1. a i ( 1 ≤ i ≤ n ) a_i(1\le i\le n) ai(1in) 为模 m m m 的简化剩余系, gcd ⁡ ( b , m ) = 1 \gcd(b,m)=1 gcd(b,m)=1,则 b ⋅ a i ( 1 ≤ i ≤ n ) b\cdot a_i(1\le i\le n) bai(1in) 也为模 m m m 的简化剩余系。

简化剩余系的性质都在欧拉函数上了。。。

欧拉函数

定义欧拉函数 ϕ ( n ) \phi(n) ϕ(n) 为小于等于 n n n 且与 n n n 互质的数的个数,即模 n n n 的简化剩余系的大小。

性质

  1. ϕ ( n ) = n ∏ p ∈ prime p ∣ n ( 1 − 1 p ) \phi(n)=n\prod\limits_{\begin{subarray}{l}p\in\text{prime}\\p|n\end{subarray}}(1-\frac 1 p) ϕ(n)=npprimepn(1p1)
  2. gcd ⁡ ( n , m ) = 1 \gcd(n,m)=1 gcd(n,m)=1,则 ϕ ( n m ) = ϕ ( n ) ϕ ( m ) \phi(nm)=\phi(n)\phi(m) ϕ(nm)=ϕ(n)ϕ(m),即 ϕ ( n ) \phi(n) ϕ(n) 为积性函数

欧拉定理

gcd ⁡ ( a , n ) = 1 \gcd(a,n)=1 gcd(a,n)=1,则 a ϕ ( n ) ≡ 1 ( m o d n ) a^{\phi(n)}\equiv1\pmod n aϕ(n)1(modn)
构造 b i ( 1 ≤ i ≤ ϕ ( n ) ) b_i(1\le i\le\phi(n)) bi(1iϕ(n)) 为模 n n n 的简化剩余系,则 c i = b i ⋅ a ( 1 ≤ i ≤ ϕ ( n ) ) c_i=b_i\cdot a(1\le i\le\phi(n)) ci=bia(1iϕ(n)) 也为模 n n n 的简化剩余系
∏ i = 1 ϕ ( n ) c i ≡ ∏ i = 1 ϕ ( n ) b i ( m o d n ) \prod\limits^{\phi(n)}_{i=1}c_i\equiv\prod\limits^{\phi(n)}_{i=1}b_i\pmod n i=1ϕ(n)cii=1ϕ(n)bi(modn)
∏ i = 1 ϕ ( n ) b i ⋅ a ≡ ∏ i = 1 ϕ ( n ) b i ( m o d n ) \prod\limits^{\phi(n)}_{i=1}b_i\cdot a\equiv\prod\limits^{\phi(n)}_{i=1}b_i\pmod n i=1ϕ(n)biai=1ϕ(n)bi(modn)
约去 ∏ i = 1 ϕ ( n ) b i \prod\limits^{\phi(n)}_{i=1}b_i i=1ϕ(n)bi,得 a ϕ ( n ) ≡ 1 ( m o d n ) a^{\phi(n)}\equiv1\pmod n aϕ(n)1(modn),证毕。

扩展欧拉定理

由欧拉定理,得到扩展欧拉定理: a n ≡ a n mod ϕ ( n ) + ϕ ( n ) ( m o d n ) a^n\equiv a^{n\>\text{mod}\>\phi(n)+\phi(n)}\pmod n ananmodϕ(n)+ϕ(n)(modn)

代码(就是快速幂,不贴了

习题

  • 洛谷P5091

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

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

相关文章

【江科大】STM32:MPU6050介绍

文章目录 MPU6050介绍结构图MPU6050参数硬件电路模块内部结构框图数据帧格式寄存器地址 MPU6050介绍 MPU6050是一个6轴姿态传感器,可以测量芯片自身X、Y、Z轴的加速度、角速度参数,通过数据融合,可进一步得到姿态角,常应用于平衡…

STM32CubeMX教程27 SDIO - 读写SD卡

目录 1、准备材料 2、实验目标 3、轮询方式读取SD卡流程 3.0、前提知识 3.1、CubeMX相关配置 3.1.0、工程基本配置 3.1.1、时钟树配置 3.1.2、外设参数配置 3.1.3、外设中断配置 3.2、生成代码 3.2.0、配置Project Manager页面 3.2.1、外设初始化调用流程 3.2.2、外设中断调用流…

北京某大厂Linux系统管理和Shell脚本笔试题

1. 写一个sed命令,修改/tmp/input.txt文件的内容,要求:(1) 删除所有空行;(2) 在非空行前面加一个"AAA",在行尾加一个"BBB",即将内容为11111的一行改为:AAA11111BBB #创建一…

现货黄金做日内交易和波段交易有何差异?

在现货黄金投资中,日内交易和波段交易都是投资者常用的手段。但投资者其实搞不懂两者有何区别,有时甚至不清楚自己做的是日内交易还是波段交易,下面我们就来讨论一下这两种交易方法的异同。 两者的区别主要是在持仓的时间上。日内交易顾名思义…

Python中的`__all__`魔法函数使用详解

概要 Python是一门灵活而强大的编程语言,提供了各种机制来控制模块的导入和访问。其中,__all__魔法函数是一种用于限制模块导入的机制,可以明确指定哪些变量、函数或类可以被导入。本文将深入探讨__all__的作用、用法以及示例,以…

C++:类和对象(中)

类的6个默认成员函数 如果一个类中什么成员都没有,简称为空类。 空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。默认成员函数:用户没有显式实现,编译器会生成…

ES文档索引、查询、分片、文档评分和分析器技术原理

技术原理 索引文档 索引文档分为单个文档和多个文档。 单个文档 新建单个文档所需要的步骤顺序: 客户端向 Node 1 发送新建、索引或者删除请求。节点使用文档的 _id 确定文档属于分片 0 。请求会被转发到 Node 3,因为分片 0 的主分片目前被分配在 …

【AI绘画】stablediffusion图生图教程!!

**手把手教你入门绘图超强的AI绘画,用户只需要输入一段图片的文字描述,即可生成精美的绘画。给大家带来了全新保姆级教程资料包 (文末可获取) ** 目录 一、图生图 1.图生图原理 2.图生图三个步骤 ①图生图基本三步法 ②提示…

深度学习如何入门,如何快速理解深度学习

深度学习是机器学习的一个分支,它使用深度神经网络来模拟人脑的工作方式,通过学习样本数据的内在规律和表示层次,让机器能够具有类似于人类的分析学习能力。深度学习的最终目标是实现人工智能的普及化,使机器能够识别、处理、分析…

Leetcode—2859. 计算 K 置位下标对应元素的和【简单】

2023每日刷题&#xff08;九十一&#xff09; Leetcode—2859. 计算 K 置位下标对应元素的和 内置函数__builtin_popcount方法实现代码 class Solution { public:int sumIndicesWithKSetBits(vector<int>& nums, int k) {int n nums.size();int ans 0;for(int i …

mac电脑安卓文件传输工具:Android File Transfer直装版

Android File Transfer&#xff08;AFT&#xff09;是一款用于在Mac操作系统上与Android设备之间传输文件。它允许用户将照片、音乐、视频和其他文件从他们的Android手机或平板电脑传输到Mac电脑&#xff0c;以及将文件从Mac上传到Android设备。 下载地址&#xff1a;https://w…

怎样编写高性能C/C++程序

本文主要讨论高性能编程&#xff0c;而且是那种“极致性能需求”。按照本人的粗浅认识&#xff0c;应该已经覆盖了绝大多数技术要点&#xff0c;但缺点是不够详细&#xff08;篇幅有限&#xff09;。本文共分为4个部分&#xff1a;总体论述、高性能网络编程、高性能数值计算、常…

【揭秘】ForkJoinTask全面解析

内容摘要 ForkJoinTask的显著优点在于其高效的并行处理能力&#xff0c;它能够将复杂任务拆分成多个子任务&#xff0c;并利用多核处理器同时执行&#xff0c;从而显著提升计算性能&#xff0c;此外&#xff0c;ForkJoinTask还提供了简洁的API和强大的任务管理机制&#xff0c…

常规的管理系统除了适用该有的范儿一定要有!气质上不能输

hello宝子们...我们是艾斯视觉擅长ui设计和前端开发10年经验&#xff01;希望我的分享能帮助到您&#xff01;如需帮助可以评论关注私信我们一起探讨&#xff01;致敬感谢感恩&#xff01; 常规的管理系统除了适用该有的范儿一定要有!气质上不能输 在现今快速发展的商业环境中…

Error:Resource not found: openni2_launch

报错信息 Resource not found: openni2_launch ROS path [0]/opt/ros/melodic/share/ros ROS path [1]/media/zhangdama/F4ACC8D7C3CD6C91/kobuki_gazebo_imitation/mount/vln-pano2real-ros/src ROS path [2]/opt/ros/melodic/share The traceback for the exception was wri…

Android音量调节修改

前言 今日公司&#xff0c;安卓设备的音量显示不正常&#xff0c;让我来修复这个bug&#xff0c;现在已修复&#xff0c;做个博客&#xff0c;记录一下&#xff0c;以后碰到类似一下子就好解决。 Android音量调节相关 路径 frameworks\base\services\core\java\com\android…

NIO-Selector详解

NIO-Selector详解 Selector概述 Selector选择器&#xff0c;也可以称为多路复⽤器。它是Java NIO的核⼼组件之⼀&#xff0c;⽤于检查⼀个或多个Channel的状态是否处于可读、可写、可连接、可接收等。通过⼀个Selector选择器管理多个Channel&#xff0c;可以实现⼀个线程管理…

Spring boot + Azure OpenAI 服务 1.使用 GPT-35-Turbo

Azure OpenAI 服务使用 GPT-35-Turbo 先决条件 maven 注意 beta.6 版本 <dependency><groupId>com.azure</groupId><artifactId>azure-ai-openai</artifactId><version>1.0.0-beta.6</version></dependency>问答工具类 pack…

C++的关键字,命名空间,缺省参数,函数重载以及原理

文章目录 前言一、C关键字(C98)二、命名空间命名空间介绍命名空间的使用 三、C输入【cin】& 输出【cout】四、缺省参数缺省参数概念缺省参数分类缺省参数的使用小结一下 五、函数重载函数重载介绍函数重载类型 六、C支持函数重载的原理--名字修饰(name Mangling)【重点】 前…

二分算法模版

二分算法模版 实数二分算法模版实数二分模版题 整数二分算法模版向上取整二分模版向下取整二分模版二分模版的注意点二分模版中check函数的实现能够使用二分的条件 二分主要分两类&#xff0c; 一类是对实数进行二分&#xff0c;一类是对整数进行二分 对整数二分又分成2种&…