中国剩余定理(CRT)与欧拉函数[数论]
中国剩余定理
——!x^n+y^n=z^n
想必大家都听过同余方程这种玩意,但是可能对于中国剩余定理有诸多不解,作为一个MOer&OIer,在此具体说明。
对于同余方程:
x≡c1(mod m1)
x≡c2(mod m2)
···
x≡cn (mod mn) [其中任意的两个mi,mj互质]
我们可以构造出一个解:
令m=Πai[0<i<=n],Mi*mi=m。
那我们可以得到一组解:
x=ΣMi*Mi-1(mod m) 接下来我们想办法证明她是唯一的:
Mi*Mi-1≡1(mod mi)
``````
证明:
假设x1与x2均为方程的解,且x1,x2 模 m不同余。
那么 mi|x1-x2
由于(mi,mj)=1,即m|x1-x2
也就是 x1≡x2(mod m)这与假设矛盾!故命题得证。
``````
当然还有更深的道理蕴含在里面。
/*添加一个概念:完全剩余系:大概是这个意思,就是一些数模a的余数为(0,1,2,L,a-1)即为模a的完全剩余系(概念说不严谨,大概意思知道就行...)*/
- 定理一:(从简单方面入手)
对于m1,m2。我们记x(1)为m1的一个完全剩余系,x(2)意思相同。
对于x(1)i+m1*x(2)j,当x(1)i,x(2)遍历m1,m2的完全剩余系时,也遍历了m1m2的完全剩余系。
``````
证明:
注意到遍历的方式只有m1m2种,我们只需要证其两两不同余即可。
若x(1)i+m1*x(2)j≡x(1)p+m1*x(2)q(mod m1m2)
那么m1m2|x(1)i+m1*x(2)j-x(1)p-m1*x(2)q => m1|x(1)i-x(1)p => i=p => x(1)i = x(1)j
那么进一步的我们还可以得到:
m2|x(2)j-x(2)q => j=q => x(2)j=x(2)q
固原命题得证。
``````
- 定理二:
当然我们希望这个式子具有对称性,所以我们考虑(m1,m2)=1的情况。
其实因为(m1,m2)=1,所以x(1)与x(1)*m2都是模m1的完全剩余系,既然这样我就可以得到
x(1)*m2+x(2)*m1当x(1),x(2)分别遍历其各自的完全剩余系时,x(1)*m2+x(2)*m1会遍历m的完全剩余系。
- 定理三:
我们想要更加一般的结论,对于n>=2,那么
m=m1*m2*L*mn,其中任意的mi与mj(i≠j)是两两互质的,Mi*mi=m,即有:
ΣMi*x(i),当每个i遍历其各自的完全剩余系时,也会遍历m的完全剩余系。
``````
证明(我们当然可以使用数学归纳法):
① 当n=2时,由定理二已知其成立。
② 我们假设当n>2时命题成立,
我们记X=Σ(x(i)*Mi/Mn+1),m=Σmi [1<=i<=n+1]
则要证的式子化为:
x(n+1)Mn+1+mn+1X,注意到mn+1与Mn+1互质,由定理二可知,定理三成立。
``````
也就是说x(i)的每一种选择与模m的完全剩余系时一一对应的,也就是说x∈[0,m-1]的同余方程解是存在且唯一的。
这时候我们再回去看欧拉函数,假设p为质数
φ(p)=p-1
φ(p^k)=p^k-p^(k-1)=p^(k-1)(p-1)
如果(p,q)互质,那么φ(pq)会等于什么呢?(猜测φ(pq)=φ(p)*φ(q))
``````
假设p1为模p的完全剩余系,q1亦然。
那么p1*q+q1*p,当p1,q1分别遍历其各自的完全剩余系,p1*q+q1*p也会遍历模pq的完全剩余系。
①注意到若(a,p)=1且a<p,
(b,q)=1且b<q
那么a*q+b*p一定没有pq的质因子,可以自己想一下。或者可以这样想:
(a*q,b*p)=1,即他们没有公共的质因子,就是说他可以表示成两组质因子分解的和,既无法因式分解,所以(a*q+b*p,pq)=1。
③ (a,p)≠1且a<p,b亦然。
那么a*q+b*p一定能够因式分解,就是一定能表示成x*y的形式,并且(x,y)≠1。
``````
有了上述定理,欧拉函数的计算方法已经得证(请读者自己领会)。
这里给出φ的计算方法:
φ(n)=n*(1-1/p1)*(1-1/p2)*L*(1-1/pk),pi为n的质因子。
本Lowbee能力有限,如有错误,请各位大佬指正。
中国剩余定理(CRT)与欧拉函数[数论]的更多相关文章
- Bzoj 2705: [SDOI2012]Longge的问题 欧拉函数,数论
2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 1959 Solved: 1229[Submit][ ...
- Bzoj 2186: [Sdoi2008]沙拉公主的困惑 乘法逆元,线性筛,欧拉函数,数论
2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 2560 Solved: 857[Submit][St ...
- 紫书 例题 10-26 UVa 11440(欧拉函数+数论)
这里用到了一些数论知识 首先素因子都大于M等价与M! 互质 然后又因为当k与M!互质且k>M!时当且仅当k mod M! 与M!互质(欧几里得算法的原理) 又因为N>=M, 所以N!为M! ...
- Bzoj 2749: [HAOI2012]外星人 欧拉函数,数论,线性筛
2749: [HAOI2012]外星人 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 568 Solved: 302[Submit][Status][ ...
- BZOJ4802 欧拉函数 数论
原文链接http://www.cnblogs.com/zhouzhendong/p/8117744.html 题目传送门 - BZOJ4802 题意概括 Description 已知N,求phi(N) ...
- GCD nyoj 1007 (欧拉函数+欧几里得)
GCD nyoj 1007 (欧拉函数+欧几里得) GCD 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 The greatest common divisor ...
- 中国剩余定理 & 欧拉函数 & 莫比乌斯反演 & 狄利克雷卷积 & 杜教筛
ssplaysecond的博客(请使用VPN访问): 中国剩余定理: https://ssplaysecond.blogspot.jp/2017/04/blog-post_6.html 欧拉函数: h ...
- 数论 - 欧拉函数模板题 --- poj 2407 : Relatives
Relatives Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11372 Accepted: 5544 Descri ...
- BZOJ-2190 仪仗队 数论+欧拉函数(线性筛)
今天zky学长讲数论,上午水,舒爽的不行..后来下午直接while(true){懵逼:}死循全程懵逼....(可怕)Thinking Bear. 2190: [SDOI2008]仪仗队 Time Li ...
随机推荐
- Spring学习(13)--- 基于Java类的配置Bean 之 @Configuration & @Bean注解
基于Java配置选项,可以编写大多数的Spring不用配置XML,但有几个基于Java的注释的帮助下解释.从Spring3.0开始支持使用java代码来代替XML来配置Spring,基于Java配置S ...
- linux tesseract 安装及部署tess4j项目的常见问题
linux上部署tess4j项目 在windows上项目是可以正常运行的,部署到Linux上后,运行报异常,异常内容为:Unable to load library 'tesseract': Nati ...
- 在项目中利用TX Text Control进行WORD文档的编辑显示处理
在很多文档管理的功能模块里面,我们往往需要对WORD稳定进行展示.编辑等处理,而如果使用微软word控件进行处理,需要安装WORD组件,而且接口使用也不见得简单易用,因此如果有第三方且不用安装Offi ...
- nmon用法
一.简介 nmon是一个简单的性能监测工具,可以监测CPU.内存.网络等的使用情况.它是一个系统监视.调优.性能测试工具,它能一次性提供大量性能相关的信息. 二.安装与执行 下载地址:http://n ...
- javaScript的一些奇妙动画
今天我给大家讲一下JavaScript中的显示隐藏.淡入淡出的效果 显示与隐藏动画效果 show()方法: show()方法会动态地改变当前元素的高度.宽度和不透明度,最终显示当前元素,此时 ...
- jQuery – 鼠标经过(hover)事件的延时处理
一.关于鼠标hover事件及延时 鼠标经过事件为web页面上非常常见的事件之一.简单的hover可以用CSS :hover伪类实现,复杂点的用js. 一般情况下,我们是不对鼠标hover事件进行延时处 ...
- windows端口占用处理工具
一.描述 笔者在最近使用tomcat时,老是会遇到这种端口占用的问题,便写了这个小的exe,用于解决windows下的端口占用问题. 好吧,其实是我实在记不住CMD下的那几行命令.这玩意的实现比较简单 ...
- jenkins跑maven项目的时候报错,看评论
Started by user admin Building in workspace /var/jenkins_home/workspace/helloworld [WS-CLEANUP] Dele ...
- Docker 初步认识
1.docker 是什么? 一个开源的应用容器引擎,个人理解 就是虚拟的应用运行环境. 2.安装Docker for windows 下载地址 :https://store.docker.com/ed ...
- Socket实现
网络实现架构 4.4BSD通过同时对多种通信协议的支持来提供通用的底层基础服务.4.4BSD支持四种不同的通信协议簇: TCP/IP(互联网协议簇) XNS(Xerox网络系统) OSI协议 Unix ...