数论-中国剩余定理

本文通过多个实例详细解析了中国剩余定理的应用方法,包括如何寻找满足特定除法余数条件的最小自然数。

久闻剩余定理大名,也略懂一二。。

不过今天认真学习了下。。留下此贴,以记之。
参考:http://eblog.cersp.com/userlog/7978/archives/2008/723693.shtml
http://book.51cto.com/art/200812/102579.htm

例1:一个数被3除余1,被4除余2,被5除余4,这个数最小是几?
题中3、4、5三个数两两互质。
则〔4,5〕=20;〔3,5〕=15;〔3,4〕=12;〔3,4,5〕=60。
为了使20被3除余1,用20×2=40;
使15被4除余1,用15×3=45;
使12被5除余1,用12×3=36。
然后,40×1+45×2+36×4=274,
因为,274>60,所以,274-60×4=34,就是所求的数。

例2:一个数被3除余2,被7除余4,被8除余5,这个数最小是几?
题中3、7、8三个数两两互质。
则〔7,8〕=56;〔3,8〕=24;〔3,7〕=21;〔3,7,8〕=168。
为了使56被3除余1,用56×2=112;
使24被7除余1,用24×5=120。
使21被8除余1,用21×5=105;
然后,112×2+120×4+105×5=1229,
因为,1229>168,所以,1229-168×7=53,就是所求的数。

例3:一个数除以5余4,除以8余3,除以11余2,求满足条件的最小的自然数。
题中5、8、11三个数两两互质。
则〔8,11〕=88;〔5,11〕=55;〔5,8〕=40;〔5,8,11〕=440。
为了使88被5除余1,用88×2=176;
使55被8除余1,用55×7=385;
使40被11除余1,用40×8=320。
然后,176×4+385×3+320×2=2499,
因为,2499>440,所以,2499-440×5=299,就是所求的数。

例4:有一个年级的同学,每9人一排多5人,每7人一排多1人,每5人一排多2人,问这个年级至少有多少人 ?(幸福123老师问的题目)
题中9、7、5三个数两两互质。
则〔7,5〕=35;〔9,5〕=45;〔9,7〕=63;〔9,7,5〕=315。
为了使35被9除余1,用35×8=280;
使45被7除余1,用45×5=225;
使63被5除余1,用63×2=126。
然后,280×5+225×1+126×2=1877,
因为,1877>315,所以,1877-315×5=302,就是所求的数。

例5:有一个年级的同学,每9人一排多6人,每7人一排多2人,每5人一排多3人,问这个年级至少有多少人 ?(泽林老师的题目)
题中9、7、5三个数两两互质。
则〔7,5〕=35;〔9,5〕=45;〔9,7〕=63;〔9,7,5〕=315。
为了使35被9除余1,用35×8=280;
使45被7除余1,用45×5=225;
使63被5除余1,用63×2=126。
然后,280×6+225×2+126×3=2508,
因为,2508>315,所以,2508-315×7=303,就是所求的数。
(例5与例4的除数相同,那么各个余数要乘的“数”也分别相同,所不同的就是最后两步。)

 

 

先写出一个两位数62,接着在62右端写这两个数字的和为8,得到628,再写末两位数字2和8的和10,得到62810,用上述方法得到一个有2006位的整数:628101123……,则这个整数的数字之和是(       )。

(2006-5)÷10=200....1

17+35*200+1=7018

前面的62810数字和为17

后面开始,以“1123581347”为循环节

共循环10次,每次的和为35

最后余1,就加上1

所以结果是17+35*200+1=7018

 

例子:PKU 1006

因为只有三个数23 28 33 且三个数两两互为质数,所以“中国剩余定理”可知
对于每一组输入数据p, e ,i, d,所求结果为:n = (R1*p + R2*e + R3*i)%21252-d
其中 R1%p=1, R2%e=1, R3%i=1;
R1 = 5544 = 28*33* 6;      //28 33 的公倍数中能被23除余1的最小整数
R2 = 14221 = 23*33*19;   //23 33 的公倍数中能被28除余1的最小整数
R3 = 1288 = 23*28* 2;      //23 28 的公倍数中能被33除余1的最小整数
       为了保证结果大于等于1且小于等于21252,结果修正为:n = (R1*p + R2*e + R3*i - d + 21252)%21252,并且如果n为0,则n = 21252为所求。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值