逆元 x
逆元:
1.首先定义:
若存在正整数a,x,m,且满足ax≡1(mod m),则称a是x的乘法逆元,或称x是a的乘法逆元.
Eg:
模7意义下,3的乘法逆元是5(或模7意义下,5的乘法逆元是3)
1)3*1%7=3%7=3 =/=1(x)
2)3*2%7=6%7=6 =/=1(x)
3)3*3%7=9%7=2 =/=1(x)
4)3*4%7=12%7=5 =/=1(x)
5)3*5%7=15%7=1 ==1 (√)
||
||
||
v
模7意义下,3的乘法逆元是5(或模7意义下,5的乘法逆元是3)
其他的求乘法逆元的方式与此类似。
2.乘法逆元存在性定理
我们来考虑一下同余方程:
ax ≡ 1(mod m)
若a 与m 互质, 则一定存在一个正整数解x, 满足x < m.
若a 与m 不互质, 则一定不存在正整数解x.
意思也就是说, 互质与乘法逆元存在互为充要条件.
3.求法
①欧拉定理/费马小定理
- 3.1欧拉定理
- 3.1.1欧拉定理公式:
aφ(p) ≡ 1(mod p)
(是对于任意互质的a,p恒成立的)
- 3.1.2推论
a*aφ(p)-1 ≡ 1(mod p)
只有通过这个公式+快速幂才能够求逆元~
- 3.1.3欧拉函数定义
欧拉函数φ(n)表示小于等于n且与n互质的正整数的个数
Eg:φ(6)=2,φ(7)=6,φ(1)=1
欧拉函数是一个数论函数, 也是一个积性函数, 可以线性筛出.
- 3.1.4欧拉函数公式:
若令n=∏ki=1 pi ci为n的质因子分解形式,则有
k pi-1
φ(n)=n∏ ----------
i=1 pi
欧拉函数可以利用容斥原理在O(sqrt(n))的时间复杂度上界中求出
②线性求逆元
③拓展欧几里得
逆元一般用拓展欧几里得算法来求得,如果为素数(常用素数有:998244353,1000000007),则经常根据费马小定理(用于降低题目的难度)得到逆元为
其推导过程如下:
例:
求如下表达式的值(已知)(|为整除号)
当然这个经典的问题有很多方法,最常见的就是扩展欧几里得,如果是素数,还可以用费马小定理!!!
但是你会发现费马小定理和扩展欧几里得算法求逆元是有局限性的,它们都会要求与
互素。实际上我们还有一种通用的求逆元方法,适合所有情况。
公式如下:
现在我们来证明它,已知,证明步骤如下
而对于(a/b)%m== 一个数
1.当m是素数的时候,根据费马小定理(不懂的可以去这儿看看),直接输出b^(n-2)即可
2.否则,就根据拓展欧几里得exgcd(b,m,x,y)
Ps:拓展欧几里得能够保证求出的x,y满足|x|+|y|最小
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath> using namespace std;
int a,b,m;
int x,y; int exgcd(int a,int b,int &x,int &y)
{
if(b==)
{
x=;
y=;
return a;
}
int r=exgcd(b,a%b,x,y),tmp;
tmp=x,x=y;
y=tmp-a/b*y;
return r;
} int fastpow(int a,int p)
{
int bb=a;int ans=;
while(p!=)
{
if(p%==)ans=ans*bb;
bb=bb*bb;
p=p/;
}
return ans;
} int main()
{
scanf("%d%d%d",&a,&b,&m);
for(int i=;i<=sqrt(m);i++)
{
if(m%i==)
{
int ans=exgcd(b,m,x,y);
printf("%d",(a*ans)%m);
return ;
}
}
printf("%d",fastpow(b,m-));
}
逆元 x的更多相关文章
- hdu5651 xiaoxin juju needs help (多重集的全排列+逆元)
xiaoxin juju needs help 题意:给你一个字符串,求打乱字符后,有多少种回文串. (题于文末) 知识点: n个元素,其中a1,a2,··· ...
- HDU 5976 数学,逆元
1.HDU 5976 Detachment 2.题意:给一个正整数x,把x拆分成多个正整数的和,这些数不能有重复,要使这些数的积尽可能的大,输出积. 3.总结:首先我们要把数拆得尽可能小,这样积才会更 ...
- Bzoj2154 Crash的数字表格 乘法逆元+莫比乌斯反演(TLE)
题意:求sigma{lcm(i,j)},1<=i<=n,1<=j<=m 不妨令n<=m 首先把lcm(i,j)转成i*j/gcd(i,j) 正解不会...总之最后化出来的 ...
- CF451E Devu and Flowers (隔板法 容斥原理 Lucas定理 求逆元)
Codeforces Round #258 (Div. 2) Devu and Flowers E. Devu and Flowers time limit per test 4 seconds me ...
- 51nod1256(乘法逆元)
题目链接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1256 题意:中文题诶~ 思路: M, N 互质, 求满足 K ...
- O(n)求1-n的逆元
转自:http://www.2cto.com/kf/201401/272375.html 新学的一个求逆元的方法: inv[i] = ( MOD - MOD / i ) * inv[MOD%i] % ...
- NOIP2011多项式系数[快速幂|组合数|逆元]
题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别为 a ,b ,k , ...
- 【板子】gcd、exgcd、乘法逆元、快速幂、快速乘、筛素数、快速求逆元、组合数
1.gcd int gcd(int a,int b){ return b?gcd(b,a%b):a; } 2.扩展gcd )extend great common divisor ll exgcd(l ...
- 【HDU 5698】瞬间移动(组合数,逆元)
x和y分开考虑,在(1,1)到(n,m)之间可以选择走i步.就需要选i步对应的行C(n-2,i)及i步对应的列C(m-2,i).相乘起来. 假设$m\leq n$$$\sum_{i=1}^{m-2} ...
- 【BZOJ-2839】集合计数 容斥原理 + 线性推逆元 + 排列组合
2839: 集合计数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 229 Solved: 120[Submit][Status][Discuss] ...
随机推荐
- SAS学习笔记40 SAS程序运行过程
当我们提交运行一个DATA步程序后,具体发生了什么事情. SAS程序与其他程序一样,在运行时都要经过两个阶段:编译(Compilation).执行(Execution) 程序首先经过编译阶段,该阶段主 ...
- spark集群安装并集成到hadoop集群
前言 最近在搞hadoop+spark+python,所以就搭建了一个本地的hadoop环境,基础环境搭建地址hadoop2.7.7 分布式集群安装与配置 本篇博客主要说明,如果搭建spark集群并集 ...
- js:把字符串转为变量使用; js下将字符串当函数去执行的方法
1 把字符串当变量使用 通过计算 string 得到的值(如果有的话).该方法只接受原始字符串作为参数 demo: var type = "car"; var newStr = & ...
- diverta 2019 Programming Contest
A:签到. #include<bits/stdc++.h> using namespace std; #define ll long long #define inf 1000000010 ...
- sql 计算奇数还是偶数
& 运算符来判断奇数还是偶数 sql判断奇数还是偶数 3&1 返回 1 2&1 返回0 0&1 返回 0
- java 框架-缓冲-Redis 2Jedis操作
https://www.cnblogs.com/wlandwl/p/redis.html Redis介绍及Jedis基础操作 1.Redis简介 Redis 是一个开源(BSD许可)的,内存中的数 ...
- Seaborn(二)之数据集分布可视化
Seaborn(二)之数据集分布可视化 当处理一个数据集的时候,我们经常会想要先看看特征变量是如何分布的.这会让我们对数据特征有个很好的初始认识,同时也会影响后续数据分析以及特征工程的方法.本篇将会介 ...
- Centos7 配置 svn服务端
转载至:Linux(阿里云Centos7)环境下搭建svn服务器以及权限配置详细步骤 本篇文章主要介绍在CentOS7中采用yum安装方式.优点:简单,一键安装,不用手动配置环境变量等.缺点:安装位置 ...
- ubuntu下使用libsvm
matlab上的代码已经八八九九了,因为涉及到GUI和网络编程的东西,所以不得已开始学python并在python上做完整版. 下面是如何在linux和python下使用libsvm 在你的pytho ...
- k2系列-开发篇
上一篇讲到K2安装的具体操作,本篇我们具体讲一下在VS环境下如何开发K2工作流. 常用工具控件说明: 节点关联线:流程各节点之间的关联线 客户端节点:流程的基本元素 服务器端节点:流程的完成标识节点 ...