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

文中有些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. 指令(Prompt)基本格式

    指令(Prompt)基本格式: 参考信息:包含文心一言完成任务时需要知道的必要背景和材料,如:报告.知识.数据库.对话上下文等 动作:需要文心一言帮你解决的事情,如:撰写.生成.总结.回答等 目标:需 ...

  2. 一份快速入门的 Makefile 教程

    目录 一份快速入门的 Makefile 教程 关于 Makefile,你应该知道的一些事情 什么是 Makefile? Makefile 能做什么? Makefile 怎么写? Makefile 与 ...

  3. LLDB辅助工具Chisel入门初探

    LLDB辅助工具Chisel入门初探 基础适用方法 使用场景 iOS开发的调试过程中,LLDB的使用难度较大等各种原因,所以更多的时间开发者们仅仅用于po.expr输出,实际上Facebook(现在该 ...

  4. 看李沐的 ViT 串讲

    ViT 概括 论文题目:AN IMAGE IS WORTH 16X16 WORDS: TRANSFORMERS FOR IMAGE RECOGNITION AT SCALE 论文地址:https:// ...

  5. MySQL自定义函数(User Define Function)开发实例——发送TCP/UDP消息

    开发背景 当数据库中某个字段的值改为特定值时,实时发送消息通知到其他系统. 实现思路 监控数据库中特定字段值的变化可以用数据库触发器实现.还需要实现一个自定义的函数,接收一个字符串参数,然后将这个字符 ...

  6. .NET App 与Windows系统媒体控制(SMTC)交互

    当你使用Edge等浏览器或系统软件播放媒体时,Windows控制中心就会出现相应的媒体信息以及控制播放的功能,如图. SMTC (SystemMediaTransportControls) 是一个Wi ...

  7. TI AM64x工业开发板硬件说明书(双核ARM Cortex-A53 + 单/四核Cortex-R5F + 单核Cortex-M4F,主频1GHz)

    前  言 本文主要介绍TL64x-EVM评估板硬件接口资源以及设计注意事项等内容. 创龙科技TL64x-EVM是一款基于TI Sitara系列AM64x双核ARM Cortex-A53 + 单/四核C ...

  8. Spring注解之构建器@Builder的用法

    简述 Builder使用创建者模式又叫建造者模式.简单来说,就是一步步创建一个对象,它对用户屏蔽了里面构建的细节,但却可以精细地控制对象的构造过程. 基础使用 @Builder 注解为你的类生成相对略 ...

  9. SpringBoot快速插入Mysql 1000万条数据

    导读 有时候为了验证系统瓶颈,需要往数据库表中插入大量数据,可以写sheel脚本插入,前几天为了插入100万条数据,走的sheel脚本(点我直达),插入速度简直无法直视,花了3小时,才插入了10万条, ...

  10. mac navicat免激活版

    Navicat 12 第一步:终端执行 sudo spctl --master-disable 第二步:下载安装即可使用 https://pan.baidu.com/s/1tHq-wqAIggD0Fo ...