PKU POJ 1006 Biorhythms 從“韓信點兵”中想到的
題目名字叫Biorhythms,翻譯過來大概是“生物節律”吧。
這道題并不難,但是,挺有意思的。
先來看一個故事
傳說西漢大將韓信,由于比較年輕,開始他的部下對他不很佩服。有一次閱兵時,韓信要求士兵分三路縱隊,結果末尾多2人,改成五路縱隊,結果末尾多3人,再改成七路縱隊,結果又余下2人,后來下級軍官向他報告共有士兵2395人,韓信立即笑笑說不對(因2395除以3余數是1,不是2),由于已經知道士兵總人數在2300?/FONT>2400之間,所以韓信根據23,128,233,------,每相鄰兩數的間隔是105,便立即說出實際人數應是2333人(因2333=128+20χ105+105,它除以3余2,除以5余3,除以7余2)。這樣使下級軍官十分敬佩,這就是韓信點兵的故事。
簡化:已知 n%3=2,n%5=3,n%7=2,求n。
再看我們這道題,讀入p,e,i,d 4個整數,已知(n+d)%23=p; (n+d)%28=e; (n+d)%33=i ,求n 。
是不是一樣呢?
呵呵,確實一樣。想到這里覺得很興奮。但是韓信是怎么計算出結果的呢?
隨便google了一下,原來這個東西叫“中國剩余定理”,《孫子算經》中就有計算方法。
韓信應該是這樣算的:
因為n%3=2,n%5=3,n%7=2且3,5,7互質
使5×7被3除余1,用35×2=70;
使3×7被5除余1,用21×1=21;
使3×5被7除余1,用15×1=15。
(70×2+21×3+15×2)%(3×5×7)=23
同樣,這道題也應該是:
使33×28被23除余1,用33×28×8=5544;
使23×33被28除余1,用23×33×19=14421;
使23×28被33除余1,用23×28×2=1288。
(5544×p+14421×e+1288×i)%(23×28×33)=n+d
n=(5544×p+14421×e+1288×i-d)%(23×28×33)
由于我們面對的是計算機,所以以上那些很大的數字,可以單獨寫程序讓電腦在近乎0的時候內求出:) 為什么要單獨寫呢?嘿嘿,為了主程序的效率著想~
程序已經出來了

2

3



4

5

6

7



8

9

10



11

12

13

14

15

16

17

18

呵呵,事情到此為止我已經十分開心了,因為我看到還有很多用各種各樣方法搞得頭昏腦脹都還沒有ac的同學們。大家加油吧~
但是,還有一點想不明白,我的Memory用了72K,查看這道題的status,很多人竟然只用了20K內存就做出來了,最強的竟然只用了4K!難道有更好的算法??百思不得其解。。。如果有人知道,請告訴我,感謝。