[学习笔记] 丢番图方程 & 同余 & 逆元 - 数论
首先,他们几个有着极大的相似性。另外,他们的各自的思想都能够很好的服务于另外几个,有助于加深理解。
文中有些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 ...
随机推荐
- ES Elasticsearch exception [type=search_phase_execution_exception, reason=all shards failed
查看日志切分:sed -n '/2022-03-21 01:50:11.785/,/2022-03-21 02:25:01.130/p' test-2022-03-21-1.log > 2203 ...
- httpx的使用
urllib和requests库已经可以爬取大多数网站的数据,但对于一些强制使用HTTP/2.0协议访问,这时urllib和requests是无法爬取数据的,因为只支持HTTP/1.1,不支持HTTP ...
- Service Mesh技术详解
深入探讨Service Mesh的基本概念和核心技术,涵盖了服务发现.负载均衡.断路器与熔断机制,以及数据平面与控制平面的详细工作原理和实现方法. 关注作者,复旦博士,分享云服务领域全维度开发技术.拥 ...
- 05-CentOS防火墙
概述 CentOS中的防火墙有很多,如SELinux.Firewall.TCP Wrappers.iptables/netfilter. 每种防火墙都有各自擅长的地方. 这里主要讲两种:SELinux ...
- springboot使用mail提示没有该类型的bean
@Autowired private JavaMailSenderImpl javaMailSender; 自动注入时提示没有该类型的Bean. 原因 没有配置邮件发送相关的配置信息. spring: ...
- Springboot整合Apollo
一.Apollo作用 随着程序功能的日益复杂,程序的配置日益增多:各种功能的开关.参数的配置.服务器的地址-- 对程序配置的期望值也越来越高:配置修改后实时生效,灰度发布,分环境.分集群管理配置,完善 ...
- Spark内核架构核心组件.txt
1.Application2.spark-submit3.Driver4.SparkContext5.Master6.Worker7.Executor8.Job9.DAGScheduler10.Tas ...
- Log4Net配置详解及输出自定义消息类示例
1.简单使用实例 1.1 添加log4net.dll的引用. 在NuGet程序包中搜索log4net并添加,此次我所用版本为2.0.17.如下图: 1.2 添加配置文件 右键项目,添加新建项, ...
- Windows Android 子系统(WSA)安装
除了Linux子系统WSL,微软还提供了安卓子系统WSA.不过对国内好像不太友好,安装也不方便. 这里说一下我的安装方法,但是可能时效性很强,现在是2022-01-20,如果日期离得太远可能不好使. ...
- idea 提交代码到GitHub
配置账户 配置Git安装目录 一般默认识别,其他参数不变 配置GitHub账户 提交到GitHub 1.VCS->import into version control -> share ...