中国剩余定理CRT(孙子定理)
中国剩余定理
$\Large(s):\left\{
\begin{aligned}
x\equiv a_1\ (mod\ m_1)\\
x\equiv a_2\ (mod\ m_2)\\
\vdots\ \ \ \ \ \ \ \ \ \ \ \ \\
x\equiv a_n\ (mod\ m_n)
\end{aligned}
\right.$
有解。证明:
因为$x\equiv(a_iM_iM_i^{-1})mod\ m_i\ \ i\in\{1,2,……,n\}$ $(MiMi^-1)\%mi=1$
又因为$a_jM_jM_j^{-1}\equiv 0\ mod\ m_i\ \ \forall i\neq j$(如果i!=j,则Mj是mi的倍数)
所以 $x\equiv(a_1M_1M_1^{-1}+a_2M_2M_2^{-1}+……+a_nM_nM_n^{-1})mod\ m_i\ \ i\in\{1,2,……,n\}$
因为mi互素
所以$x\equiv(a_1M_1M_1^{-1}+a_2M_2M_2^{-1}+……+a_nM_nM_n^{-1})mod\ M$
#include<cstdio>
#define ll long long
inline void exgcd(ll a,ll b,ll &x,ll &y){//a,b,x,y同ax+by=gcd(a,b)中的a,b,x,y
if(!b){
x=,y=;return;
}
ll t;
exgcd(b,a%b,x,y);
t=x,x=y,y=t-(a/b)*y;
}
inline ll Inverse(ll a,ll p){//求a模p的乘法逆元
ll x,y;
exgcd(a,p,x,y);
return x;
}
inline ll CRT(ll a[],ll m[],ll n){//求解同余方程组
ll M=,_Mi,Mi,ans=;//_Mi为Mi的乘法逆元(%m[i]意义下的)
for(int i=;i<n;i++)M*=m[i];
for(int i=;i<n;i++){
Mi=M/m[i];
_Mi=Inverse(Mi,m[i]);
ans=(ans+Mi*_Mi*a[i])%M;
}
if(ans<)ans+=M;
return ans;//返回最小正整数解
}
int main(){
return ;
}
例题
/******************************************************************
中国剩余定理
******************************************************************/
#include<cstdio>
#define ll long long
#define maxn 15
inline void exgcd(ll a,ll b,ll &x,ll &y){//a,b,x,y同ax+by=gcd(a,b)中的a,b,x,y
if(!b){
x=,y=;return;
}
ll t;
exgcd(b,a%b,x,y);
t=x,x=y,y=t-(a/b)*y;
}
inline ll Inverse(ll a,ll p){//求a模p的乘法逆元
ll x,y;
exgcd(a,p,x,y);
return x;
}
inline ll CRT(ll a[],ll m[],ll n,ll &M){//求解同余方程组
ll _Mi,Mi,ans=;//_Mi为Mi的乘法逆元(%m[i]意义下的)
for(int i=;i<n;i++)M*=m[i];
for(int i=;i<n;i++){
Mi=M/m[i];
_Mi=Inverse(Mi,m[i]);
ans=(ans+Mi*_Mi*a[i])%M;
}
if(ans<)ans+=M;
return ans;//返回最小正整数解
}
ll p[maxn],a[maxn];
ll M=,ans,n,m;
int main(){
// freopen("HanXin.in","r",stdin);
// freopen("HanXin.out","w",stdout);
scanf("%lld%lld",&n,&m);
for(int i=;i<m;i++){
scanf("%lld%lld",p+i,a+i);
}
ans=CRT(a,p,m,M);
if(ans>n)printf("-1");
else printf("%lld",(n-ans)%M);
return ;
}
扩展——求解模数不互质的线性方程组
$\Large (s):\left\{
\begin{aligned}
x\equiv a_1\ (mod\ m_1)\\
x\equiv a_2\ (mod\ m_2)\\
\vdots\ \ \ \ \ \ \ \ \ \ \ \ \\
x\equiv a_n\ (mod\ m_n)
\end{aligned}
\right.$
如果m1,m2……mn不互质,则中国剩余定理无法运用
这时我们可以对方程组进行转换,比如前两个方程可以变为:
$x=a_1+k_1m_1$和$x=a_2+k_2m_2$
则$a_2-a_1=k_1m_1-k_2m_2$
只有k1,k2是未知,我们用扩展欧几里得求出最小的k1(如果a2-a1%gcd(m1,m2)!=0,则无解)
求解最小k1:
设$q*m_1+y*m_2=gcd(m1,m2)$
用exgcd(m1/gcd(m1,m2),m2/gcd(m1,m2),q,y)解出最小q,
最小的$k_1=q*(a_2-a_1)/gcd(m_1,m_2)$;
带入$x=a_1+k_1m_1$可以求出满足前两个方程的解
这时,记当前x为x',
整个方程组的解x一定就满足$x\equiv x'(mod\ lcm(m_1,m_2))$
将这个方程加入方程组,重复上面步骤,每次消去一个方程,最后一个x'就是答案
注意:m1,m2,……,mn的最小公倍数不要爆容器
#include<cstdio>
#include<cstdlib>
#define ll long long
inline ll gcd(ll a,ll b){
return b?gcd(b,a%b):a;
}
inline ll lcm(ll a,ll b){
return a*b/gcd(a,b);
}
inline void exgcd(ll a,ll b,ll &x,ll &y){//a,b,x,y同ax+by=gcd(a,b)中的a,b,x,y
if(!b){
x=,y=;return;
}
ll t;
exgcd(b,a%b,x,y);
t=x,x=y,y=t-(a/b)*y;
}
inline void merge(ll a1,ll m1,ll a2,ll m2,ll &a3,ll &m3){//将方程x=a1+k1m1和x=a2+k2m2合并为x=a3+k3m3;
ll d=gcd(m2,m1),a=a2-a1,q,y;
if(a%d)exit();//无解
m3=lcm(m1,m2);
exgcd(m1/d,m2/d,q,y);
a3=a/d*q*m1+a1;
((a3%=m3)+=m3)%=m3;
}
inline ll solve(ll a[],ll m[],ll n){//求解同余方程组
ll a1=a[],m1=m[];
for(int i=;i<n;i++){
merge(a1,m1,a[i],m[i],a1,m1);
}
return (a1%m1+m1)%m1;//返回最小正整数解
}
int main(){
return ;
}
中国剩余定理CRT(孙子定理)的更多相关文章
- 【bzoj1951】【古代猪文】Lucas定理+欧拉定理+孙子定理
(上不了p站我要死了,当然是游戏原画啊) Description (题面倒是很有趣,就是太长了) 题意: 一个朝代流传的猪文文字恰好为N的k分之一,其中k是N的一个正约数(可以是1和N).不过具体是哪 ...
- 《孙子算经》之"物不知数"题:中国剩余定理
1.<孙子算经>之"物不知数"题 今有物不知其数,三三数之剩二,五五数之剩七,七七数之剩二,问物几何? 2.中国剩余定理 定义: 设 a,b,m 都是整数. 如果 m ...
- acm数论之旅--中国剩余定理
ACM数论之旅9---中国剩余定理(CRT)(壮哉我大中华╰(*°▽°*)╯) 中国剩余定理,又名孙子定理o(*≧▽≦)ツ 能求解什么问题呢? 问题: 一堆物品 3个3个分剩2个 5个5个分剩3个 ...
- POJ 1006 中国剩余定理
#include <cstdio> int main() { // freopen("in.txt","r",stdin); ; while(sca ...
- gcd,扩展欧几里得,中国剩余定理
1.gcd: int gcd(int a,int b){ ?a:gcd(b,a%b); } 2.中国剩余定理: 题目:学生A依次给n个整数a[],学生B相应给n个正整数m[]且两两互素,老师提出问题: ...
- ACM数论之旅9---中国剩余定理(CRT)(壮哉我大中华╰(*°▽°*)╯)
中国剩余定理,又名孙子定理o(*≧▽≦)ツ 能求解什么问题呢? 问题: 一堆物品 3个3个分剩2个 5个5个分剩3个 7个7个分剩2个 问这个物品有多少个 解这题,我们需要构造一个答案 我们需要构造这 ...
- 29-中国剩余定理CRT
https://blog.csdn.net/u010468553/article/details/38346195 中国剩余定理[数论] 2014年08月02日 12:55:59 阅读数:2351 中 ...
- 【bzoj3782】上学路线 dp+容斥原理+Lucas定理+中国剩余定理
题目描述 小C所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M).小C家住在西南角,学校在东北角.现在有T个路口进行施工,小C不能通过这些路口.小C喜欢走最短的路径到达目的 ...
- NOI 2018 屠龙勇士 (拓展中国剩余定理excrt+拓展欧几里得exgcd)
题目大意:略 真是一波三折的一道国赛题,先学了中国剩余定理,勉强看懂了模板然后写的这道题 把取出的宝剑攻击力设为T,可得Ti*x=ai(mod pi),这显然是ax=c(mod b)的形式 这部分用e ...
随机推荐
- JDK9新特性实战:简化流关闭新姿势。
做Java开发的都知道,每个资源的打开都需要对应的关闭操作,不然就会使资源一直占用而造成资源浪费,从而降低系统性能. 关于资源的关闭操作,从JDK7-JDK9有了不少的提升及简化. JDK6 在JDK ...
- printk 函数消息是如何记录的
printk 函数将消息写入一个 LOG_BUF_LEN 字节长的环形缓存, 长度值从 4 KB 到 1 MB, 由配置内核时选择. 这个函数接着唤醒任何在等待消息的进程, 就是说, 任何在系统 ...
- Python全栈开发:json与pickle
#!/usr/bin/env python # -*- coding;utf-8 -*- """ 正解(序列化):将Python数据类型转换成json或者pickle格式 ...
- openSUSE 安装compass,mkmf.rb can't find,checking for ffi.h...extconf.rb failed
安装compass时,提示 Fetching: sass-.gem (%) Successfully installed sass- Fetching: ffi-.gem (%) Building n ...
- 【9.14NOIP模拟pj】wtaxi 题解——搜索
[9.14NOIP模拟pj]wtaxi 题目简化 有K辆车,N个人,上车给D元,只有S分钟.上车后无论多少人都要给D元,原地等多少分钟就没了多少元.求最小花费的钱. 我的思路 毫无疑问,此题可以用搜索 ...
- 0901NOIP模拟测试赛后总结
突然想学迪哥列一下分数线搞清楚自己和别人的差距. rank1- 5- 6-分. 差距很大啊.尤其是和某kyh.大家都开玩笑说天皇是个变态.但是事实摆在这儿,同样坐在机房这么长的时间,人家又AK了. 我 ...
- 第十二章 Odoo 12开发之报表和服务端 QWeb
报表是业务应用非常有价值的功能,内置的 QWeb 引擎是报表的默认引擎.使用 QWeb 模板设计的报表可生成 HTML 文件并被转化成 PDF.也就是说我们可以很便捷地利用已学习的 QWeb 知识,应 ...
- sql自定义日期函数,返回范围内日期和星期数表。
Create function [dbo].[FUN_GenerateTime] ( @begin_date datetime, -- 起始时间 @end_date datetime -- 结束时间 ...
- 第二周——1.项目中MySQL版本问题
1.版本升级 经组长推荐,本地安装的是mysql-8.0.11,而主项目用的还是版本5.6, 因此需要升级版本. 首先,更新驱动:下载mysql-connector-java-8.0.11,将E:\P ...
- linux下安装rabbitmq 集群
1.下载erlang官网地址 http://www.erlang.org/download 挑选合适的版本 然后 wget 比如目前18.3运行命令 wget http://erlang.org/do ...