逆元:

丢线

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的更多相关文章

  1. hdu5651 xiaoxin juju needs help (多重集的全排列+逆元)

    xiaoxin juju needs help 题意:给你一个字符串,求打乱字符后,有多少种回文串.                      (题于文末) 知识点: n个元素,其中a1,a2,··· ...

  2. HDU 5976 数学,逆元

    1.HDU 5976 Detachment 2.题意:给一个正整数x,把x拆分成多个正整数的和,这些数不能有重复,要使这些数的积尽可能的大,输出积. 3.总结:首先我们要把数拆得尽可能小,这样积才会更 ...

  3. Bzoj2154 Crash的数字表格 乘法逆元+莫比乌斯反演(TLE)

    题意:求sigma{lcm(i,j)},1<=i<=n,1<=j<=m 不妨令n<=m 首先把lcm(i,j)转成i*j/gcd(i,j) 正解不会...总之最后化出来的 ...

  4. CF451E Devu and Flowers (隔板法 容斥原理 Lucas定理 求逆元)

    Codeforces Round #258 (Div. 2) Devu and Flowers E. Devu and Flowers time limit per test 4 seconds me ...

  5. 51nod1256(乘法逆元)

    题目链接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1256 题意:中文题诶~ 思路: M, N 互质, 求满足 K ...

  6. O(n)求1-n的逆元

    转自:http://www.2cto.com/kf/201401/272375.html 新学的一个求逆元的方法: inv[i] = ( MOD - MOD / i ) * inv[MOD%i] % ...

  7. NOIP2011多项式系数[快速幂|组合数|逆元]

    题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别为 a ,b ,k , ...

  8. 【板子】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 ...

  9. 【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} ...

  10. 【BZOJ-2839】集合计数 容斥原理 + 线性推逆元 + 排列组合

    2839: 集合计数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 229  Solved: 120[Submit][Status][Discuss] ...

随机推荐

  1. (一)Struts2 基础

    一.Struts简介 1.1 历史 虽然Struts 2号称是一个全新的框架,但这仅仅是相对Struts 1而言.Struts 2与Struts 1相比,确实有很多革命性的改进,但它并不是新发布的新框 ...

  2. 奇妙的算法【4】-汉诺塔&哈夫曼编码

    1,汉诺塔问题[还是看了源码才记起来的,记忆逐渐清晰] 汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着6 ...

  3. JS OOP -03 JS类的实现

    JS类的实现: a.理解类的实现机制 b.使用prototype对象定义类成员 c.一种JS类的设计模式 a.理解类的实现机制 在JS中可以使用function关键字来定义一个类. 添加类的成员,在函 ...

  4. 前端开发 Vue -2npm

    npm介绍 说明:npm(node package manager)是nodejs的包管理器,用于node插件管理(包括安装.卸载.管理依赖等) 使用npm安装插件:命令提示符执行npm instal ...

  5. spring cloud Eureka 配置信息

    Eureka instance 一个服务,如:订单系统,会部署多台服务器,而每台服务器上提供的服务就是instance; 负载配置. Eureka service 指的是服务,提供一种特定功能的服务, ...

  6. Python练习_初识数据类型_day3

    题目 1. 作业 1,有变量name = "aleX leNb" 完成如下操作: 1) 移除 name 变量对应的值两边的空格,并输出处理结果 2) 移除name变量左边的&quo ...

  7. 2019年6月SAP发布的未来ABAP平台的发展方向

    未来ABAP平台将始终是这些产品的技术平台: S/4HANA On-Premises和Cloud将基于一个统一的ABAP codeline: SAP云平台上的ABAP编程环境: 什么是SAP Clou ...

  8. 判断一个ip地址是动态的还是静态的

    要确定计算机的IP是静态IP还是动态IP,请执行以下步骤: 通过单击开始打开命令提示符并搜索CMD,然后单击cmd.exe 键入ipconfig / all.  找到“以太网本地连接”列表.找到“ I ...

  9. 用js刷剑指offer(包含min函数的栈)

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 牛客网链接 js代码 const stack1 = [] const stack2 = ...

  10. tensorflow实战笔记(20)----textRNN

    https://www.cnblogs.com/jiangxinyang/p/10208227.html https://www.cnblogs.com/jiangxinyang/p/10241243 ...