费马小定理

快速幂

理论

a n = a × a × ⋯ × a a^n = a × a × \cdots × a an=a×a××a,暴力的计算需要 O(n) 的时间。
快速幂使用二进制拆分和倍增思想,仅需要 O(logn) 的时间。

对 n 做二进制拆分,例如, 3 13 = 3 ( 1101 ) 2 = 3 8 ⋅ 3 4 ⋅ 3 1 3^{13} = 3^{(1101)_2} = 3^8 \cdot 3^4 \cdot 3^1 313=3(1101)2=383431
对 a 做平方倍增,例如, 3 1 , 3 2 , 3 4 , 3 8 ⋯ ⋯ 3^1, 3^2, 3^4, 3^8 \cdots\cdots 31,32,34,38⋯⋯

n 有 logn + 1个二进制位,知道了 a 1 , a 2 , a 4 , a 8 , ⋯ , a 2 logn a^1, a^2, a^4, a^8, \cdots, a^{2^{\text{logn}}} a1,a2,a4,a8,,a2logn后,只需要计算 logn + 1 次乘法就可以了。

快速幂可以应用在任何具有结合律的运算中,例如,取模运算矩阵乘法等。

例如, ( 3 13 ) % p = ( ( 3 8 ) % p ⋅ ( 3 4 ) % p ⋅ ( 3 1 ) % p ) % p (3^{13})\%p = ((3^8)\%p \cdot (3^4)\%p \cdot (3^1)\%p)\%p (313)%p=((38)%p(34)%p(31)%p)%p

模板

int quickpow(int a, int n) {int res = 1;while (n) {if (n & 1) {res = res * a;}a = a * a;n >>= 1;}return res;
}

例题

P1226 【模板】快速幂
题目描述
给你三个整数 a , b , p a,b,p a,b,p,求 a b m o d p a^b \bmod p abmodp

输入格式
输入只有一行三个整数,分别代表 a , b , p a,b,p a,b,p

输出格式
输出一行一个字符串 a^b mod p=s,其中 a , b , p a,b,p a,b,p 分别为题目给定的值, s s s 为运算结果。

输入输出样例 #1

输入 #1

2 10 9

输出 #1

2^10 mod 9=7

说明/提示
样例解释

2 10 = 1024 2^{10} = 1024 210=1024 1024 m o d 9 = 7 1024 \bmod 9 = 7 1024mod9=7

数据规模与约定
对于 100 % 100\% 100% 的数据,保证 0 ≤ a , b < 2 31 0\le a,b < 2^{31} 0a,b<231 a + b > 0 a+b>0 a+b>0 2 ≤ p < 2 31 2 \leq p \lt 2^{31} 2p<231

#include<bits/stdc++.h>
using namespace std;
int quickpow(long long a, long long b, long long p) {int res = 1;while (b) {if (b & 1) {res = res * a % p;}a = a * a % p;b >>= 1;}return res;
}
int main() {long long  a, b, p;cin >> a >> b >> p;cout << a << "^" << b << " mod " << p << "=" << quickpow(a, b, p);return 0;
}

理论

同余式
如果两整数a, b模m的余数相同,则称a, b模m同余,记为a ≡ b (mod m) 。例:8 ≡ 2 (mod 3)

乘法逆元
若a, b互质,且满足同余方程ax ≡ 1 (mod b),则称x为a模b的乘法逆元,记作a⁻¹
例:8x ≡ 1 (mod 5),解得x = 2, 7, 12…

费马小定理
若p为质数,且a, p互质,则a^(p - 1) ≡ 1 (mod p)
例:4^(3 - 1) ≡ 1 (mod 3)

证明
构造一个与p互质的序列A = {1, 2, 3, …, p - 1},现在来证明:∏(i = 1)^(p - 1) a × Ai ≡ ∏(i = 1)^(p - 1) Ai (mod p)
每个a × Ai (mod p)的余数必是独一无二的,且a × Ai (mod p) < p ,则必与Ai (mod p)的余数集合相同。故得证。
所以a^(p - 1) × ∏(i = 1)^(p - 1) Ai ≡ ∏(i = 1)^(p - 1) Ai (mod p) 。证毕。
例:p = 5, A = {1, 2, 3, 4}, a = 2。
则aA = {2, 4, 6, 8}, aA%p = {2, 4, 1, 3}, A%p = {1, 2, 3, 4}

例题

给两个数a, p,p是质数,求a模p的乘法逆元

由费马小定理
a^(p - 1) ≡ 1 (mod p),得 a × a^(p - 2) ≡ 1 (mod p),
所以a^(p - 2) 就是a模p的乘法逆元。
用快速幂求即可。

#include<bits/stdc++.h>
using namespace std;
int a, p;
int quickpow(int a, int b, int p) {int res = 1;while (b) {if (b & 1) {res = res * a % p;}a = a * a % p;b >>= 1;}return res;
}
int main() {cin >> a >> p;if (a % p) {printf("%d\n", quickpow(a, p - 2, p));}return 0;
}

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

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

相关文章

ADGaussian:用于自动驾驶的多模态输入泛化GS方法

25年4月来自香港中文大学和浙大的论文“ADGaussian: Generalizable Gaussian Splatting for Autonomous Driving with Multi-modal Inputs”。 提出 ADGaussian 方法&#xff0c;用于可泛化的街道场景重建。所提出的方法能够从单视图输入实现高质量渲染。与之前主要关注几何细…

js中this指向问题

在js中&#xff0c;this关键字的指向是一个比较重要的概念&#xff0c;它的值取决于函数的调用方式。 全局状态下 //全局状态下 this指向windowsconsole.log("this", this);console.log("thiswindows", this window); 在函数中 // 在函数中 this指向win…

我的NISP二级之路-03

目录 一.ISMS 二.IP 三.http 四.防火墙 五.文件 解析 解析 六.攻击 解析 解析 七.风险管理工程 八.信息系统安全保护等级 九.我国信息安全保障 一.ISMS 1.文档体系建设是信息安全管理体系(ISMS)建设的直接体现&#xff0c;下列说法不正确的是&#xff1a; A&#…

HarmonyOS应用开发者高级-编程题-001

题目一&#xff1a;跨设备分布式数据同步 需求描述 开发一个分布式待办事项应用&#xff0c;要求&#xff1a; 手机与平板登录同一华为账号时&#xff0c;自动同步任务列表任一设备修改任务状态&#xff08;完成/删除&#xff09;&#xff0c;另一设备实时更新任务数据在设备…

动态列表的数据渲染、新增、编辑等功能开发及数据处理

说一个比较繁琐的功能吧&#xff0c;我使用的是 vue element UI vxe-table 来实现的这个动态列表&#xff0c;其实呢 vxe-table 这个表格插件里边有动态表格 vxe-grid 只需要通过表头数组里边的 field: name, 与表体数组里的 name: Test1, 对应上就行了&#xff0c;很简单吧…

Linux学习笔记——文件系统基础与根文件系统详解

文件系统基础与根文件系统详解 什么是文件系统&#xff1f;什么是根文件系统&#xff08;Root File System&#xff09;&#xff1f;一句话理解&#xff1a;更详细地说&#xff1a; 根文件系统为什么重要&#xff1f;1. 启动依赖2. 提供根目录 /3. 支持挂载其他文件系统4. 提供…

R语言进行聚类分析

目录 简述6种系统聚类法 实验实例和数据资料&#xff1a; 上机实验步骤&#xff1a; 进行最短距离聚类&#xff1a; 进行最长距离聚类&#xff1a; 进行中间距离聚类&#xff1a; 进行类平均法聚类&#xff1a; 进行重心法聚类&#xff1a; 进行ward.D聚类&#xff1a;…

【回眸】Linux 内核 (十四)进程间通讯 之 信号量

前言 信号量概念 信号量常用API 1.创建/获取一个信号量 2.改变信号量的值 3. 控制信号量 信号量函数调用 运行结果展示 前言 上一篇文章介绍的共享内存有局限性,如:同步与互斥问题、内存管理复杂性问题、数据结构限制问题、可移植性差问题、调试困难问题。本篇博文介…

记录IBM服务器检测到备份GPT损坏警告排查解决过程

服务器设备&#xff1a;IBM x3550 M4 Server IMM默认IP地址&#xff1a;192.168.70.125 用户名&#xff1a;USERID 密码&#xff1a;PASSW0RD&#xff08;注意是零0&#xff09; 操作系统&#xff1a;Windows Hyper-V Server 2016 IMM Web System Status Warning&#xff1…

“Pseudo Global Warming”:伪全球变暖PGW

“Pseudo Global Warming”&#xff1a;伪全球变暖PGW PGW方法概述&#x1f50d; 一、PGW 方法的定义&#x1f9e0; 二、PGW 方法的基本原理&#x1f6e0;️ 三、PGW 方法的主要步骤&#x1f4c8; 四、PGW 模拟时常涉及的变量&#x1f4ca; 五、PGW 方法的优/缺点&#x1f4da;…

2025-04-06 Unity Editor 2 —— GUILayout

文章目录 常用组件1 Label 文本标签2 TextField / TextArea / PasswordField 输入框3 Butto / RepeatButton 按钮4 Horizontal / Vertical 方向布局5 Box 自动布局框6 ScrollView 滚动视图7 Horizontal / VerticalSlider 滑动条8 Area GUI 区域9 Window 窗口10 Toolbar 工具栏1…

Qt 交叉编译详细配置指南

一、Qt 交叉编译详细配置 1. 准备工作 1.1 安装交叉编译工具链 # 例如安装ARM工具链(Ubuntu/Debian) sudo apt-get install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf# 或者64位ARM sudo apt-get install gcc-aarch64-linux-gnu g++-aarch64-linux-gnu 1.2 准备目标…

用PointNet++训练自己的数据集(语义分割模型semseg)

&#xff08;1&#xff09;训练部件分割&#xff08;partseg&#xff09;模型和检测自己点云并将结果保存txt&#xff0c;请看博主上两篇文章 &#xff08;2&#xff09;本文背景是将pipe点云上的缺陷和本体检测出来&#xff0c;即1种语义场景&#xff08;pipe&#xff09;&…

kotlin中主构造函数是什么

一 Kotlin 中的主构造函数 主构造函数&#xff08;Primary Constructor&#xff09;是 Kotlin 类声明的一部分&#xff0c;用于在 创建对象时初始化类的属性。它不像 Java 那样是一个函数体&#xff0c;而是紧跟在类名后面。 主构造函数的基本定义 class Person(val name: S…

PHP 过滤器

PHP 过滤器 引言 PHP作为一种广泛使用的服务器端脚本语言&#xff0c;提供了强大的数据处理能力。在处理数据时&#xff0c;确保数据的安全性和准确性至关重要。PHP过滤器&#xff08;Filters&#xff09;就是用来对数据进行预处理和后处理的工具。本文将详细介绍PHP过滤器的…

【WebRTC】开源项目Webrtc-streamer介绍

WebRTC-Streamer 这是一个用于通过简单的信令机制&#xff08;参见 api&#xff09;流式传输 WebRTC 媒体源的实验项目&#xff0c;支持以下媒体源&#xff1a; 捕获设备 屏幕捕获 mkv 文件 RMTP/RTSP 源 同时该项目也兼容 WHEP 接口。 注意 * 在线演示已停止&#xff0c…

【Java设计模式】第9章 原型模式讲解

9. 原型模式 9.1 原型模式讲解 定义:通过拷贝原型实例创建新对象,无需调用构造函数。特点: 创建型模式无需了解创建细节适用场景: 类初始化消耗资源多对象创建过程繁琐(如属性赋值复杂)循环体中需创建大量对象优点: 性能优于直接new简化创建流程缺点: 必须实现clone()…

【Java集合】LinkedList源码深度分析

参考笔记&#xff1a;java LinkedList 源码分析&#xff08;通俗易懂)_linkedlist源码分析-CSDN博客 目录 1.前言 2.LinkedList简介 3.LinkedList的底层实现 4.LinkedList 与 ArrayList 的对比 4.1 如何选择 4.2 对比图 5.LinkedList 源码Debug 5.1 add(E e) &#xff…

openssl源码分析之加密模式(modes)

openssl实现分组加密模式&#xff08;例如AES128-CBC的CBC部分&#xff09;的模块名字叫做modes&#xff0c;源代码位于 https://gitee.com/gh_mirrors/openssl/tree/master/crypto/modes 博主又打不开github了TT&#xff0c;只能找个gitee镜像 头文件是modes.h。 该模块目前…

Java 搭建 MC 1.18.2 Forge 开发环境

推荐使用 IDEA 插件 Minecraft Development 进行创建项目 创建完成后即可进行 MOD 开发。 但是关于 1.18.2 的开发教程太少&#xff0c;因此自己研究了一套写法&#xff0c;写法并非是最优的但是是探索开发MOD中的一次笔记和记录 GITHUB: https://github.com/zimoyin/zhenfa…