首先,他们几个有着极大的相似性。另外,他们的各自的思想都能够很好的服务于另外几个,有助于加深理解。

文中有些letax公式抽风了,全屏之后应该能看得见……

线性丢番图方程

丢番图不是个图啊!他是个man……

现在主要说的是二元线性丢番图方程:通用形式为 \(ax+by=c\)。其中常数全都为整数。很像不定方程对吧?现在在整数范围内讨论他的解。

定理

对于方程 \(ax+by=c\),其中 \(a\)、\(b\)、\(c\) 均为整数。令 \(d=gcd(a,b)\),该方程有解(有无限解)的充要条件是 \(d\mid c\),该方程无解的充要条件是 \(d\nmid c\)。另外,若 \(x_0\),\(y_0\),为方程的一个特解,那么所有解可以表示为:

\[\begin{split}
x=x_0+(b\mid d)n\\y=y_0-(a\mid d)n
\end{split}
\]

证明

1、令 \(a=ed\) \(b=fd\),于是有 \(c=ax+by=edx+fdy=d(ex+fy)\),证毕。

2、规定方恒的一组特解 \(ax_0+by_0=c\),且有方程的解 \(ax+by=c\)。

作差得:

\[\begin{split}
ax-ax_0+by-by_0=0\\
a(x-x_0)=b(y_0-y)
\end{split}
\]

两边同除 \(d\) 得:

\[\begin{split}
(a/d)(x-x_0)=(b/d)(y_0-y)\\
\end{split}
\]

因为 \((a/d)\) 与 \((b/d)\) 互质,且 \((x-x_0)\) 和 \((y_0-y)\) 均为整数,所以一定存在一个整数 \(n\) 使得 \(n(a/d)=y_0-y\),可得 \(y=y_0-n(a/d)\),同理 \(x=x_0+n(b/d)\)。对于这个结果可以带回原方程中并尝试化简即可验证其正确性。

扩展欧几里得算法

求解上述方程的关键是找到一个特解。因为该特解和求 \(GCD\) 有关,所以求特解也用到了欧几里得求 \(GCD\) 的思路,成为扩展欧几里得算法。下面阐述具体步骤:

  1. 对于方程 \(ax+by=c\) ,先用扩欧求 \(ax+by=gcd(a,b)\) 的解,代码如下。
inline ll extend_gcd(ll a, ll b, ll &x, ll &y){
if(!b) {x = 1, y = 0; return a;}
ll d = extend_gcd(b, a%b, y, x);
y -= a/b * x;
return d;
}

首先,根据欧几里得算法的性质,总有一刻使得 \(a_2x_2 + 0y_2 = a_2\) ,并且此时剩下的 \(a_2\) 即为 \(gcd(a,b)\)。于是可求得 \(x_2=1,y_2=0\)。再退一个狮子看:根据欧几里得算法的过程得:

\[\begin{split}
b_1x_2+(a_1\%b_1)y_2&=a_2\\
b_1x_2+[a_1-b_1\cdot\frac{a_1}{b_1}]y_2&=a_2\\
b_1x_2+a_1y_2-b_1\cdot\frac{a_1}{b_1}y_2&=a_2\\
b_1(x_2-\frac{a_1}{b_1}y_2)+a_1y_2&=a_2\\
\end{split}
\]

又 \(b_1y_1+a_1x_1=a_2\),所以上下对应可以得到递推式 \(y_1=x_2-\frac{a_1}{b_1}y_2,x_1=y_2\),于是便有了如上代码。

  1. 但有了上面的操作还不够,因为咱只求了 \(c=d=gcd(a,b)\) 时的特解,不过也很简单了,只需要在狮子左右同乘 \(c/d\) 即可。

  2. 题目通常会求最小正整数解,所以得出的解还要进行一步操作: \((x\%(b/d)+b/d)\%(b/d)\)

同余

假如现在有个狮子 \(a\ mod\ M=b\),其中涉及到的所有数都为整数。那么他就可以写作 \(a\equiv b\ (mod M)\)。

[学习笔记] 丢番图方程 & 同余 & 逆元 - 数论的更多相关文章

  1. Mobius反演与积性函数前缀和演学习笔记 BZOJ 4176 Lucas的数论 SDOI 2015 约数个数和

    下文中所有讨论都在数论函数范围内开展. 数论函数指的是定义域为正整数域, 且值域为复数域的函数. 数论意义下的和式处理技巧 因子 \[ \sum_{d | n} a_d = \sum_{d | n} ...

  2. 数论算法 剩余系相关 学习笔记 (基础回顾,(ex)CRT,(ex)lucas,(ex)BSGS,原根与指标入门,高次剩余,Miller_Rabin+Pollard_Rho)

    注:转载本文须标明出处. 原文链接https://www.cnblogs.com/zhouzhendong/p/Number-theory.html 数论算法 剩余系相关 学习笔记 (基础回顾,(ex ...

  3. 五一DAY1数论学习笔记

    by ruanxingzhi 整除性 如果a能把b除尽,也就是没有余数,则我们称a整除b,亦称b被a整除.(不是除以,是整除!!) 记作:\(a|b\) |这个竖杠就是整除符号 整除的性质 自反性 对 ...

  4. [学习笔记]NTT——快速数论变换

    先要学会FFT[学习笔记]FFT——快速傅里叶变换 一.简介 FFT会爆精度.而且浮点数相乘常数比取模还大. 然后NTT横空出世了 虽然单位根是个好东西.但是,我们还有更好的东西 我们先选择一个模数, ...

  5. OI数学 简单学习笔记

    基本上只是整理了一下框架,具体的学习给出了个人认为比较好的博客的链接. PART1 数论部分 最大公约数 对于正整数x,y,最大的能同时整除它们的数称为最大公约数 常用的:\(lcm(x,y)=xy\ ...

  6. 「学习笔记」FFT 之优化——NTT

    目录 「学习笔记」FFT 之优化--NTT 前言 引入 快速数论变换--NTT 一些引申问题及解决方法 三模数 NTT 拆系数 FFT (MTT) 「学习笔记」FFT 之优化--NTT 前言 \(NT ...

  7. 初等数论学习笔记 III:数论函数与筛法

    初等数论学习笔记 I:同余相关. 初等数论学习笔记 II:分解质因数. 1. 数论函数 本篇笔记所有内容均与数论函数相关.因此充分了解各种数论函数的名称,定义,符号和性质是必要的. 1.1 相关定义 ...

  8. [学习笔记] 多项式与快速傅里叶变换(FFT)基础

    引入 可能有不少OIer都知道FFT这个神奇的算法, 通过一系列玄学的变化就可以在 $O(nlog(n))$ 的总时间复杂度内计算出两个向量的卷积, 而代码量却非常小. 博主一年半前曾经因COGS的一 ...

  9. OI知识点|NOIP考点|省选考点|教程与学习笔记合集

    点亮技能树行动-- 本篇blog按照分类将网上写的OI知识点归纳了一下,然后会附上蒟蒻我的学习笔记或者是我认为写的不错的专题博客qwqwqwq(好吧,其实已经咕咕咕了...) 基础算法 贪心 枚举 分 ...

  10. 快速傅里叶变换(FFT)学习笔记(其二)(NTT)

    再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 写在前面 一些约定 前置知识 同余类和剩余系 欧拉定理 阶 原根 求原根 NTT ...

随机推荐

  1. FFmpeg开发笔记全目录(FFmpeg开发实战详解,含直播系统的搭建过程)

    ​记录下FFmpeg的学习笔记目录,完整的FFmpeg开发实战内容详见<FFmpeg开发实战:从零基础到短视频上线>一书. 下面是补充的FFmpeg开发笔记内容目录,主要是对<FFm ...

  2. nacos v2.2 k8s部署启动报错:nacos server did not start because dumpservice bean construction failure. errMsg102, errllsg dataSource or tableName is null

    背景 最近搭建个nacos环境,用的镜像是2.2版本的,yaml如下: nacos-conf apiVersion: v1 kind: ConfigMap metadata: name: nacos- ...

  3. 【iOS】自定义CALayer可能会出现没有动画过程但有动画结果的解析

    按照计划是要做成这样的动画 可是结果变成了这样 (有时候最重要的不是结果而是过程,日常鸡汤) 结果没有问题说明delegate中- (void)animationDidStop:(CAAnimatio ...

  4. Springboot3.0+spring6.0+JDK17+配置jsp和打war包

    由于某些缘故,公司的产品需要升级,但并不希望花费大量时间重写前端代码(原来的就不是前后分离的).所以虽然spring和springboot都升级为最新的版本,但是依然还是需要支持jsp,并继续用打包为 ...

  5. 【动手学深度学习】第三章笔记:线性回归、SoftMax 回归、交叉熵损失

    这章感觉没什么需要特别记住的东西,感觉忘了回来翻一翻代码就好. 3.1 线性回归 3.1.1 线性回归的基本元素 1. 线性模型 \(\boldsymbol{x}^{(i)}\) 是一个列向量,表示第 ...

  6. 在Linux中使用crontab

    背景 虽然不是专业运维,但是在嵌入式开发中还是需要懂一点的.部门内部搞服务器最厉害的就是我了,汗. 参考: https://blog.csdn.net/longgeaisisi/article/det ...

  7. Electron 的 安装

    背景 因为搞嵌入式开发的时候,每次烧写不同版本的固件的时候,经常需要重命名,有时候烧错版本我也不知道: 因此我认为对固件的管理比较麻烦,所以我希望能够有一个比较好的工具来做管理,找了一圈没有发现合适的 ...

  8. mysql判断两个字符串(以逗号分隔)是否存在交集

    转载:https://blog.csdn.net/username666/article/details/107815331?utm_medium=distribute.pc_relevant.non ...

  9. github中的子模块(git submodule)

    git中支持引用另外一个开源库,并且可以指定依赖的分支或者提交记录号. 比如fltk-rs 库的fltk-sys模块依赖了库 cfltk 并指明了依赖的提交是 8a56507 甚至可以嵌套,毕竟库自身 ...

  10. MyBatis学习篇

    什么是MyBatis (1)Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动.创建连接.创建statement等繁杂 ...