[学习笔记] 丢番图方程 & 同余 & 逆元 - 数论
首先,他们几个有着极大的相似性。另外,他们的各自的思想都能够很好的服务于另外几个,有助于加深理解。
文中有些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\),为方程的一个特解,那么所有解可以表示为:
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\)。
作差得:
ax-ax_0+by-by_0=0\\
a(x-x_0)=b(y_0-y)
\end{split}
\]
两边同除 \(d\) 得:
(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\) 的思路,成为扩展欧几里得算法。下面阐述具体步骤:
- 对于方程 \(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\)。再退一个狮子看:根据欧几里得算法的过程得:
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\),于是便有了如上代码。
但有了上面的操作还不够,因为咱只求了 \(c=d=gcd(a,b)\) 时的特解,不过也很简单了,只需要在狮子左右同乘 \(c/d\) 即可。
题目通常会求最小正整数解,所以得出的解还要进行一步操作: \((x\%(b/d)+b/d)\%(b/d)\)
同余
假如现在有个狮子 \(a\ mod\ M=b\),其中涉及到的所有数都为整数。那么他就可以写作 \(a\equiv b\ (mod M)\)。
[学习笔记] 丢番图方程 & 同余 & 逆元 - 数论的更多相关文章
- Mobius反演与积性函数前缀和演学习笔记 BZOJ 4176 Lucas的数论 SDOI 2015 约数个数和
下文中所有讨论都在数论函数范围内开展. 数论函数指的是定义域为正整数域, 且值域为复数域的函数. 数论意义下的和式处理技巧 因子 \[ \sum_{d | n} a_d = \sum_{d | n} ...
- 数论算法 剩余系相关 学习笔记 (基础回顾,(ex)CRT,(ex)lucas,(ex)BSGS,原根与指标入门,高次剩余,Miller_Rabin+Pollard_Rho)
注:转载本文须标明出处. 原文链接https://www.cnblogs.com/zhouzhendong/p/Number-theory.html 数论算法 剩余系相关 学习笔记 (基础回顾,(ex ...
- 五一DAY1数论学习笔记
by ruanxingzhi 整除性 如果a能把b除尽,也就是没有余数,则我们称a整除b,亦称b被a整除.(不是除以,是整除!!) 记作:\(a|b\) |这个竖杠就是整除符号 整除的性质 自反性 对 ...
- [学习笔记]NTT——快速数论变换
先要学会FFT[学习笔记]FFT——快速傅里叶变换 一.简介 FFT会爆精度.而且浮点数相乘常数比取模还大. 然后NTT横空出世了 虽然单位根是个好东西.但是,我们还有更好的东西 我们先选择一个模数, ...
- OI数学 简单学习笔记
基本上只是整理了一下框架,具体的学习给出了个人认为比较好的博客的链接. PART1 数论部分 最大公约数 对于正整数x,y,最大的能同时整除它们的数称为最大公约数 常用的:\(lcm(x,y)=xy\ ...
- 「学习笔记」FFT 之优化——NTT
目录 「学习笔记」FFT 之优化--NTT 前言 引入 快速数论变换--NTT 一些引申问题及解决方法 三模数 NTT 拆系数 FFT (MTT) 「学习笔记」FFT 之优化--NTT 前言 \(NT ...
- 初等数论学习笔记 III:数论函数与筛法
初等数论学习笔记 I:同余相关. 初等数论学习笔记 II:分解质因数. 1. 数论函数 本篇笔记所有内容均与数论函数相关.因此充分了解各种数论函数的名称,定义,符号和性质是必要的. 1.1 相关定义 ...
- [学习笔记] 多项式与快速傅里叶变换(FFT)基础
引入 可能有不少OIer都知道FFT这个神奇的算法, 通过一系列玄学的变化就可以在 $O(nlog(n))$ 的总时间复杂度内计算出两个向量的卷积, 而代码量却非常小. 博主一年半前曾经因COGS的一 ...
- OI知识点|NOIP考点|省选考点|教程与学习笔记合集
点亮技能树行动-- 本篇blog按照分类将网上写的OI知识点归纳了一下,然后会附上蒟蒻我的学习笔记或者是我认为写的不错的专题博客qwqwqwq(好吧,其实已经咕咕咕了...) 基础算法 贪心 枚举 分 ...
- 快速傅里叶变换(FFT)学习笔记(其二)(NTT)
再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其二)(NTT) 写在前面 一些约定 前置知识 同余类和剩余系 欧拉定理 阶 原根 求原根 NTT ...
随机推荐
- 58同城的登录(RSA算法)
Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` 58同城的登录(RSA算法) 日期:2016-11-23 ...
- JSON文件存储
JSON 文件存储 JSON,全称为 JavaScript Object Notation, 也就是 JavaScript 对象标记,通过对象和数组的组合来表示数据,构造简洁但是结构化程度非常高,是一 ...
- 简单理解IOC控制反转和DI依赖注入
用过.net core框架的同学都知道,框架默认支持"构造函数"注入引用对象的方式.使用.net core框架也有一段时间了,最近去了解了一下到底什么是"依赖注入&quo ...
- Jenkins从github拉取项目,github有更新,自动进行构建,实现自动集成
使用git之前的准备工作 1. 搭建Jenkins的机器上,有安装git,配置git的安装地址,Jenkins配置Git的安装地址 2. Global Tool Configuration - > ...
- Apache Kylin(三)Kylin上手
Kylin 上手 根据Kylin 官方给出的测试数据,我们实际操作一下 Kylin. 1. 导入 Hive 数据 首先创建一个project,在界面左上角有个"Add Project&quo ...
- 关于docker-compose up -d 出现超时情况处理
由于要搭建一个ctf平台,用docker一键搭建是出现超时情况 用了很多办法,换源,等之类的一样没办法,似乎它就是只能用官方那个一样很怪. 只能用一种笨办法来处理了,一个个pull. 打个比如: 打开 ...
- mysqldump备份时保持数据一致性分析--master-data=2 --single-transaction
对MySQL数据进行备份,常见的方式如以下三种,可能有很多人对备份时数据一致性并不清楚 1.直接拷贝整个数据目录下的所有文件到新的机器.优点是简单.快速,只需要拷贝:缺点也很明显,在整个备份过程中新机 ...
- 嵌入式必看!全志T113-i+玄铁HiFi4核心板硬件说明资料分享
目 录 1 硬件资源 2 引脚说明(篇幅问题,暂不提供详细内容) 3 电气特性 4 机械尺寸 5 底板设计注意事项 硬件资源 SOM-TLT113核心板板载CPU.ROM.RAM.晶振.电源.LED等 ...
- BI小班课程表:PowerBI、finebi、quickbi,每周开课
为了帮助更多BI的友友更好的接触BI,并应用于实践工作中,我决定将我这些年的工作经验和付费咨询的实际经验,拿出一部分基础并且实用的知识和方法整理成课程.其中 PowerBI十节课,计划20个小时: F ...
- Spring中文官方文档
Spring 中文文档 https://springdoc.cn/ Spring Boot 中文文档 https://www.docs4dev.com/docs/zh/spring-boot/1.5. ...