【数论】不定方程&逆元&中国剩余定理
一、不定方程
要求逆元,首先要知道什么是不定方程。
已知a,b,c,求解x,y,形如ax + by = c 的方程就是不定方程。
不定方程有两种解的情况:
1.无解
2.存在且有无限的解
那么,如何判断解的情况呢?
这时候,只需要拿出gcd就可以了,
若gcd(a,b) | c,则方程存在解,为什么呢
因为我们要使用扩展欧几里得来求不定方程,我们都知道欧几里得是求
ax + by = gcd(a,b)
中的 x,y的,因此如果我们要把c代换成gcd(a,b)的话,c一定是gcd(a,b)的整数倍,因此gcd(a,b) | c,因此如果c不是gcd(a,b)的整数倍的话,该不定方程无解。
接下来,就要解这个方程了
因为之前我们得到c一定是gcd(a,b)的整数倍,所以设c = k * gcd(a,b),则 k * x 和 k * y就是方程的一组解,很好理解,因为我们要求
ax + by = c
代入扩展欧几里得
ax + by = gcd(a,b)
因为二者是等价的,且 c = k * gcd(a,b),所以两边同乘k
k * (ax + by) = k * gcd(a,b)
化简得
k * x * a + k * y * b = k * gcd(a,b)
将k * gcd(a,b) 等量代换为 c,得到
k*x * a + k*y * b = c
所以对于扩展欧几里得,k*x和k*y就是该不定方程的一个解。
现在有特解,需要求通解:
因为有了解,所以它存在无限的解,所以设t为任意常数代入扩展欧几里得方程,设p1a + q1b = gcd(a,b)
设p = p1 * t
q = q1 * t
显然,因为 p1a + q1b = gcd(a,b)
所以pa + qb = gcd(a,b) * t
两边同除以gcd(a,b)
得到pa / gcd(a,b) + qb / gcd(a,b) = t
两边同除t
得到p1a / gcd(a,b) + q1b / gcd(a,b) = 1
p1a / gcd(a,b) + q1b / gcd(a,b) = 1
p1*(a / gcd(a,b) ) + q1*(b / gcd(a,b)) = 1
根据之前扩展欧几里得的公式,在ax + by = c中,
c必须是gcd(a,b)的整数倍,现在c = 1,gcd(a,b) = gcd( a / gcd(a,b) , b / gcd(a,b) )
所以c必须是gcd( a / gcd(a,b) , b / gcd(a,b) )的整数倍,且 c = 1,所以gcd( a / gcd(a,b) , b / gcd(a,b) ) 只能等于1,
所以a / gcd(a,b) 和 b / gcd(a,b)必须是互质的,这样方程才有解。
知道了判断条件后,我们就可以用扩展欧几里得求不定方程的通解。
二、同余&逆元
接下来需要了解一个概念,叫做同余:
如果 a mod m = b mod m,则称 a,b 在模 m 的意义下同余
可以写成 a ≡ b(mod m)
同余有以下的性质:
a ≡ a(mod m)
若 a ≡ b(mod m),则 b ≡ a(mod m)
若 a ≡ b(mod m); b ≡ c(mod m),则 a ≡ c(mod m)
若 a ≡ b(mod m), c ≡ d(mod m),则
a + c ≡ b + d(mod m)
a - c ≡ b - d(mod m)
ac ≡ bd(mod m)
通过上述定义,可以得出ax ≡ 1(mod m) 这个同余方程
等同于求解不定方程 ax - my = 1
所以求解ax ≡ 1(mod m)就变成了求解ax - my = 1,所以求解同余方程相当于求解不定方程。
这时候,我们可以引入逆元的定义:
逆元素是指一个可以取消另一给定元素运算的元素,
所以设a的逆元为x,则
ax = 1
在模m的情况下则为
ax ≡ 1(mod m)
这恰恰是一个同余方程,所以可以转化为ax - my = 1,用exgcd求解这个不定方程。
三、中国剩余定理(求同余方程组)
那么如何求解同余方程组呢?
同余方程组:
x ≡ a1(mod m1)
x ≡ a2(mod m2)
...
x ≡ an(mod mn)
在gcd(m1,m2,m3,...,mn) = 1(m1,m2,...,mn互质)时解同余方程组,求解x的最小非负整数解。
这时候设m = ∏(i = 1, n)mi,Mi = m/mi,
设 Miti = 1(mod mi) ,即ti为Mi在模mi情况下的逆元
因为m是m1~mn的公倍数,且Mi = m/mi,所以Mi是除了mi以外的m1~mn的公倍数,
k为除了i以外的1~n的中的整数,则 Mi = 0 (mod mk) ,即 mk | Mi
所以,aiMiti = 0 (mod mk) 所以只要模数是m1~mn之间且模数不是mi,aiMiti 就等于 0
因为我们定义 Miti = 1(mod mi)
所以 aiMiti = ai (mod mi),所以只要模数是mi,aiMiti 就等于ai
所以aiMiti只有在mod mi的时候才等于ai,mod 其它模数的时候都等于0
因此x = ∑(i = 1, n) aiMiti 时,对于每个方程组:
x = ai(mod mi)
代入x = ∑(i = 1, n) aiMiti 得
∑(i = 1, n) aiMiti = ai (mod mi)
在两边一起 mod mi,
设i = i1时
所以i只要不等于i1,aiMiti都等于0
所以 ai1 = ai1 (mod mi1)
所以x = ∑(i = 1, n) aiMiti 时,方程组有解
此时求出的x是特解,显然,x+km(k为整数)是通解。
易证如果要求最小整数解,只要把x对m取模即可。
中国剩余定理证毕Q.E.D
【数论】不定方程&逆元&中国剩余定理的更多相关文章
- acm数论之旅--中国剩余定理
ACM数论之旅9---中国剩余定理(CRT)(壮哉我大中华╰(*°▽°*)╯) 中国剩余定理,又名孙子定理o(*≧▽≦)ツ 能求解什么问题呢? 问题: 一堆物品 3个3个分剩2个 5个5个分剩3个 ...
- [TCO 2012 Round 3A Level3] CowsMooing (数论,中国剩余定理,同余方程)
题目:http://community.topcoder.com/stat?c=problem_statement&pm=12083 这道题还是挺耐想的(至少对我来说是这样).开始时我只会60 ...
- 数论E - Biorhythms(中国剩余定理,一水)
E - Biorhythms Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Subm ...
- (伪)再扩展中国剩余定理(洛谷P4774 [NOI2018]屠龙勇士)(中国剩余定理,扩展欧几里德,multiset)
前言 我们熟知的中国剩余定理,在使用条件上其实是很苛刻的,要求模线性方程组\(x\equiv c(\mod m)\)的模数两两互质. 于是就有了扩展中国剩余定理,其实现方法大概是通过扩展欧几里德把两个 ...
- 洛谷P2480 [SDOI2010]古代猪文(费马小定理,卢卡斯定理,中国剩余定理,线性筛)
洛谷题目传送门 蒟蒻惊叹于一道小小的数论题竟能涉及这么多知识点!不过,掌握了这些知识点,拿下这道题也并非难事. 题意一行就能写下来: 给定\(N,G\),求\(G^{\sum \limits _{d| ...
- hihocode 九十七周 中国剩余定理
题目1 : 数论六·模线性方程组 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:今天我听到一个挺有意思的故事! 小Hi:什么故事啊? 小Ho:说秦末,刘邦的将军 ...
- POJ1006——中国剩余定理
题目:http://poj.org/problem?id=1006 中国剩余定理:x= m/mj + bj + aj 讲解:http://www.cnblogs.com/MashiroSky/p/59 ...
- NOI 2018 屠龙勇士 (拓展中国剩余定理excrt+拓展欧几里得exgcd)
题目大意:略 真是一波三折的一道国赛题,先学了中国剩余定理,勉强看懂了模板然后写的这道题 把取出的宝剑攻击力设为T,可得Ti*x=ai(mod pi),这显然是ax=c(mod b)的形式 这部分用e ...
- [洛谷P4777] [模板] 扩展中国剩余定理
扩展中国剩余定理,EXCRT. 题目传送门 重温一下中国剩余定理. 中国剩余定理常被用来解线性同余方程组: x≡a[1] (mod m[1]) x≡a[2] (mod m[2]) ...... x≡a ...
随机推荐
- sqlserver 如何按年按月创建分区函数
我创建了分区函数如下:create partition function pf_month1(varchar(8))as range left for values ('20120131','2012 ...
- 记一次server 2008 R2的按装过程
项目上一直在用的dell务器在去年年底突然出现系统过期,导致c盘的东西全部丢失.我们用激活工具激活,还是没能找回丢失的东西. 为了装这个系统,跟同事一起折腾了好些次,最后发现安装服务器的时候有个磁盘阵 ...
- 新闻内页 上一篇写一篇问题,ID不连续,不用链表
y要什么链表? 用sql查询上一篇 SELECT id,title FROM t_article WHERE id<10 ORDER BY id DESC LIMIT 1; 用sql查下一篇 S ...
- Navicat12激活,最新版本v12.1.18,原版激活[windows]
1.navicat_premium原版安装包 :官网下载地址2.注册工具 :github地址 本次用到的软件我已经打包好 : 蓝奏云 我安装navicat的路径在:I:\Navicat P ...
- Redis学习笔记03-持久化
redis是一个内存型数据库,这就意味着,当主机重启或者宕机时,内存中的数据会被清空,redis可能会丢失数据.为了保存数据,实现数据持久化就必须要有一种机制,可以将redis数据库的数据保留在硬盘上 ...
- 洛谷P3300 城市规划
题意:给你一个6 * n的网格题,单点修改,询问区间联通块数.n <= 10w 解:看起来就很显然的一道题......线段树每个点用一个ufs维护连通性.完了. 我为了方便思考把图转成横着的了. ...
- html文档加载顺序简单理解
html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...
- 手残,盘符前边多打一个空格导致的message d:\WEB_APP_QuChongFu\file\五月.xlsx (文件名、目录名或卷标语法不正确。)
尝试读取并解析一个excel文件,一直提示错误 但是有个原始数据,导入就没问题 对比了一下,好像也就是字母d的大小写有区别 我先把大写的D改成小写的试试,如果是大小写问题,那应该抛出异常 好吧,好像并 ...
- MarioTCP, take it..
MrioTCP,超级马里奥,顾名思义,他不仅高效,而且超级简易和好玩.同时他可以是一个很简洁的Linux C 开发学习工程.毫不夸张的说,如果全部掌握这一个工程,你会成为一个Linux C的牛人:当然 ...
- python实例 函数
#! /usr/bin/python # -*- coding: utf8 -*- def sum(a,b): return a+b func = sum r = func(5,6) prin ...