基础数论——EXGCD
1.前言
\(皆さん、こんにちは。\)今天我们来讲 \(EXGCD\) 。(扩展欧几里得)
既然是扩展嘛,那肯定有不扩展的,也就是 \(GCD\) 。
我们都知道 \(GCD\) 怎么写:
ll GCD(ll X,ll Y){ return Y==0?X:GCD(Y,X%Y);}
然后今天就要讲它的升级版: \(EXGCD\) 。
2.讲解
上面一段就是 \(GCD\) 的写法,它能够快速解决最大公约数问题。
那么 \(EXGCD\) 就是要解决下面的这个问题:
\(a\times q\equiv c \pmod{p}\)
已知整数 \(q\) , \(p\) , \(c\) ,求整数 \(a\) 。
那么我们现在把问题转化一下,显然我们不可能直接对这个问题进行求解。
\(a\times q + b\times p = c\)
模 \(p\) 相当于就是加上一些 \(p\) 或者减去一些,我们用一个未知量 \(b\) 来表示 \(p\) 的数量。但相较于第一个式子,这个式子更加简洁。
所以现在我们就是要求出 \(a\) 和 \(b\) 的值。
由于是模 \(p\) 意义下的,所以我们令 \(a\) , \(b\) 都是非负整数。
我们设 \(d=gcd(q,p)\) ,那么可得以下式子:
\(d \times \dfrac{q}{d} \times a + d \times \dfrac{p}{d} \times b = d \times \dfrac{c}{d}\)
由于 \(gcd(q,p) \mid q\) 且 \(gcd(q,p) \mid p\) ,那么 \(\dfrac{q}{d}\) 和 \(\dfrac{p}{d}\) 就是整数,那么 \(\dfrac{c}{d}\) 也是整数,所以 \(gcd(q,p) \mid c\) 。
那么如果我们求解了以下式子:
\(x\times q + y\times p = gcd(q,p)\)
然后令 \(x\) 乘上 \(\dfrac{c}{gcd(q,p)}\) 就是 \(a\) 的值了。
我们设 \(x_1\) , \(y_1\) 为 \(gcd(q,p)\) 的解。
\(x_1 \times q + y_1 \times p = gcd(q,p)\) ①
然后设 \(x_2\) , \(y_2\) 为 \(gcd(p,q\ mod\ p)\) 的解。
\(x_2 \times p + y_2 \times (q\ mod\ p) = gcd(p,q\ mod\ p)\)
显然 \(gcd(p,q\ mod\ p)\) 和 \(gcd(q,p)\) 是相等的,都是求 \(p\) 和 \(q\) 的最大公约数,所以得:
\(x_2 \times p + y_2 \times (q\ mod\ p) = gcd(q,p)\) ②
接下来把 ③ 式的 “\(q\ mod\ p\)” 展开得:
\(x_2 \times p + y_2 \times q - y_2 \times \left\lfloor\dfrac{q}{p}\right\rfloor \times p = gcd(q,p)\) ③
由 ①、③ 二式得, \(x_1=y_2\) 、 \(y_1=x_2-y_2 \times \left\lfloor\dfrac{q}{p}\right\rfloor\) 。
所以我们发现, \(p\) 和 \(q\) 的解是由 \(q\) 和 \((p\ mod\ q)\) 推过来的,所以我们可以在求 \(q\) 和 \(p\) 的最大公约数递归返回的过程中求解 \(x\) 和 \(y\) 。
当 \(p\) 为 \(0\) 的时候 \(q\) 为最大公约数,此时的 \(x=1\) , \(y=0\) 。
这样 \(EXGCD\) 就讲完了。
3.代码
#include<bits/stdc++.h>
using namespace std;
long long Q,P,X,Y;
long long Exgcd(long long Q,long long P,long long &X1,long long &Y1){
if(!P){ X1=1;Y1=0; return Q;}
long long X2,Y2,D=Exgcd(P,Q%P,X2,Y2);
X1=Y2;Y1=X2-(Q/P)*Y2;
return D;
}
int main(){
scanf("%lld%lld",&Q,&P);
Exgcd(Q,P,X,Y);
while(X<0) X=X+P;
printf("%lld\n",X%P);
return 0;
}
\(Thanks for Watch.\)
\(皆さん、さよなら。\)
基础数论——EXGCD的更多相关文章
- LightOJ1214 Large Division 基础数论+同余定理
Given two integers, a and b, you should check whether a is divisible by b or not. We know that an in ...
- HDU-1576 A/B 基础数论+解题报告
HDU-1576 A/B 基础数论+解题报告 题意 求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973) (我们给定的A必能被B整除,且gcd(B,9973) = 1). 输入 数据 ...
- RSA算法原理——(2)RSA简介及基础数论知识
上期为大家介绍了目前常见加密算法,相信阅读过的同学们对目前的加密算法也算是有了一个大概的了解.如果你对这些解密算法概念及特点还不是很清晰的话,昌昌非常推荐大家可以看看HTTPS的加密通信原理,因为HT ...
- POJ 2891 Strange Way to Express Integers 中国剩余定理 数论 exgcd
http://poj.org/problem?id=2891 题意就是孙子算经里那个定理的基础描述不过换了数字和约束条件的个数…… https://blog.csdn.net/HownoneHe/ar ...
- ACM&OI 基础数论算法专题
ACM&OI 基础数学算法专题 一.数论基础 质数及其判法 (已完结) 质数的两种筛法 (已完结) 算数基本定理与质因数分解 (已完结) 约数与整除 (已完结) 整除分块 (已完结) 最大公约 ...
- HDU 1299 基础数论 分解
给一个数n问有多少种x,y的组合使$\frac{1}{x}+\frac{1}{y}=\frac{1}{n},x<=y$满足,设y = k + n,代入得到$x = \frac{n^2}{k} + ...
- NOIp 基础数论知识点总结
推荐阅读 NOIp 数学知识点总结: https://www.cnblogs.com/greyqz/p/maths.html Basic 常用素数表:https://www.cnblogs.com/g ...
- HDU 1060 Leftmost Digit 基础数论
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1060 这道题运用的是数学方法. 假设S=n^n.两边同时取对数,得到lgS=nlgn.即有S=10 ...
- hdoj1905 Pseudoprime numbers (基础数论)
Problem Description Fermat's theorem states that for any prime number p and for any integer a > 1 ...
随机推荐
- mybatis的关系映射
一.多对一的映射关系 举例:根据员工编号查询员工所在部门的部门信息 第一步,需要在多的一方也就是员工实体类中持有一的一方部门实体类的引用 第二步,在dao接口中声明方法 第三步,在mapper中实现该 ...
- Appium+Python-项目实践一
一.前言 前面讲了环境搭建和常用的元素定位,后续会持续以项目实践的方式去慢慢学习以及整理各方面的知识点,具体不会详细阐述,但会贴上完整代码,想要了 ...
- 给你的Java程序拍个片子吧:jstack命令解析
前言 如果有一天,你的Java程序长时间停顿,也许是它病了,需要用jstack拍个片子分析分析,才能诊断具体什么病症,是死锁综合征,还是死循环等其他病症,本文我们一起来学习jstack命令~ jsta ...
- vue中mixins的使用方法和注意点(详2)(异步请求的情况)
当混合里面包含异步请求函数,而我们又需要在组件中使用异步请求函数的返回值时,我们会取不到此返回值,如下: mixin中 组件中 控制台 解决方案:不要返回结果而是直接返回异步函数 mixin中 组件中 ...
- 曹工谈Spring Boot:Spring boot中怎么进行外部化配置,一不留神摔一跤;一路debug,原来是我太年轻了
spring boot中怎么进行外部化配置,一不留神摔一跤:一路debug,原来是我太年轻了 背景 我们公司这边,目前都是spring boot项目,没有引入spring cloud config,也 ...
- Spring IoC createBean 方法详解
前言 本篇文章主要分析 Spring IoC 的 createBean() 方法的流程,以及 bean 的生命周期. 下面是一个大致的流程图: 正文 AbstractAutowireCapableBe ...
- npm run build 时 报 __webpack_public_path__ = window.webpackPublicPath; 中的windows未定义
原本 webpack.js在webpack.config.babel.js同目录下,在app.jsx中引用,用mac打包没问题,但是window就报window未定义,改到src和app.jsx同目录 ...
- 点击劫持ClickJacking
原文:https://beenle-xiaojie.github.io/2019/01/07/ClickJacking/ 引言 当我们的页面嵌入到一个iframe中时,安全测试提出一个于我而言很新鲜的 ...
- jQuery根据元素值删除数组元素的方法
http://www.jb51.net/article/68349.htm 本文实例讲述了jQuery根据元素值删除数组元素的方法.分享给大家供大家参考.具体如下: 例如删除C这个元素 ,前提不知道C ...
- excel导入DataTable
http://www.cnblogs.com/top5/archive/2010/03/12/1684559.html --下载excel的dll http://bbs.csdn.net/topics ...