当前位置: 首页 > ops >正文

算法提升之数学(快速幂+逆元求法)

今天给大家分享快速幂的相关知识

1.快速幂的基本内容

2.快速幂的代码

3.费马小定理

4.逆元

问题描述

给出 n,p,求 n−1modp。其中,n−1modp 指存在某个整数0≤a<p,使得 namodp=1,此时称 a为 n 的逆元,即 a=n−1。数据保证 p 是质数且 nmodp≠0。

输入格式

输入包含一行,为两个整数 n,p。

输出格式

输出包括一行,为一个整数,表示n−1modp。

输入案例:

3 5

输出案例:

2

代码部分:

#include <bits/stdc++.h>
using namespace std;
using ll=long long;
ll qmi(ll a,ll b,ll p){ll res=1;while(b){if(b&1)res=res*a%p;a=a*a%p;b>>=1;}return res;
}
ll inv(ll a,ll p){return qmi(a,p-2,p);
}
int main()
{ll n,p;cin>>n>>p;cout<<inv(n,p)<<'\n';return 0;
}

这是求解逆元的模版题,题目比较基础,大家可以记忆理解。

问题描述

费马是一位著名的数学家,为了解决某些复杂的数学问题,他经常需要计算模逆元。直接计算模逆元非常耗时,但费马发现了一个简单的方法来快速计算模逆元,这与他之前的一个数学发现有关。

模逆元:如果 p 是素数,并且 a是一个不被p 整除的整数,那么 a在模 p 下的逆元是 ap−2modp。这是因为根据费马小定理,我们有 ap−1≡1modp。所以,ap−2≡1modp,这意味着 ap−2是 a 在模 p 下的逆元。

现在给定两个正整数 a 和 p。计算 a 在模 p 下的逆元,并确保 p 是一个素数。

输入格式

输入包含两个正整数,分别为 a 和 p。

输出格式

输出 a 在模 p下的逆元。如果逆元不存在(即 a 能被 p 整除),输出 Inverse doesn't exist

输入案例:

3 7

输出案例:

5

代码部分:

#include <bits/stdc++.h>
using namespace std;
using ll=long long;
ll qmi(ll a,ll b,ll p){ll res=1;while(b){if(b&1)res=res*a%p;a=a*a%p;b>>=1;}return res;
}
bool isprime(ll a){if(a<2)return false;for(ll i=2;i<a/i;i++){if(a%i==0)return false;}return true;
}
int main()
{ll a,p;cin>>a>>p;if(a%p==0){cout<<"Inverse doesn't exist"<<'\n';return 0;}if(isprime(p)){cout<<qmi(a,p-2,p)<<'\n';}return 0;
}

希望今天题目对大家能有所帮助,今天的分享就到这里,希望大家多多关注。

http://www.xdnf.cn/news/16840.html

相关文章:

  • 【20min 急速入门】使用Demucs进行音轨分离
  • Redis7 String类型数据
  • 【iOS】KVO
  • MyBatisPlus之CRUD接口(IService与BaseMapper)
  • 28Rsync免密传输与定时备份
  • 关于Web前端安全防御XSS攻防的几点考虑
  • Spring Boot 全 YAML 配置 Liquibase 教程
  • C++之vector类的代码及其逻辑详解 (中)
  • DockerFile文件执行docker bulid自动构建镜像
  • CMake指令:mark_as_advanced
  • Python序列去重高级指南:保持顺序的高效去重技术
  • 错误: 找不到或无法加载主类 原因: java.lang.ClassNotFoundException
  • 云原生三剑客:Kubernetes + Docker + Spring Cloud 实战指南与深度整合
  • 分类任务当中常见指标 F1分数、recall、准确率分别是什么含义
  • 类似 Pixso 但更侧重「网页 / 软件界面设计」「前后端可视化开发」的工具
  • 【贪心】P11112 [ROI 2024] 机器人物流 (Day 1)|普及+
  • 基于python多光谱遥感数据处理、图像分类、定量评估及机器学习方法应用
  • Java函数式编程之【Stream终止操作】【下】【二】【收集器toMap()】【叁参数收集操作collect()】
  • Maven项目和Spring项目的异同
  • 企业资产|企业资产管理系统|基于springboot企业资产管理系统设计与实现(源码+数据库+文档)
  • Docker容器中文PDF生成解决方案
  • 计算机网络:为什么IPv6没有选择使用点分十进制
  • Pytorch-02数据集和数据加载器的基本原理和基本操作
  • Matplotlib - Python图表可视化利器
  • 面试小总结
  • vue引入阿里巴巴矢量图库的方式
  • 内网穿透系列十:高性能内网穿透工具 rathole,支持Docker一键部署
  • ubuntu 系统风扇控制软件 CoolerControl
  • AI驱动SEO关键词智能进化
  • Ubuntu18网络连接不上也ping不通网络配置问题排查与解决方法