“今有物不知其数,三三数之剩二,五五数之剩三,七七数之剩二,问物几何?”这个问题就是韩信点兵。
传说西汉大将韩信,由于相对年轻,最初他的部下对他不很佩服。有一次阅兵时,韩信标准士兵分三路纵队,结果末尾多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)。这样使下级军官十分敬佩,这就是韩信点兵的经历。
这一类题目又叫中国剩余定理,在世界上是很有名的,它不仅有趣,而且在现代数学和电子计算机的计算中,都有应用,这是值得大家中华民族引以为荣的。
韩信点兵又称为中国剩余定理,相传汉高祖刘邦问大将军韩信统御兵士多少,韩信答说,每3人一列余1人、5人一列余2人、7人一列余4人、13人一列余6人……。刘邦茫然而不知其数。
大家先思考下列的问题:设兵不满一万,每5人一列、9人一列、13人一列、17人一列都剩3人,则兵有多少?
首先大家先求5、9、13、17之最小公倍数9945(注:因为5、9、13、17为两两互质的整数,故其最小公倍数为这些数的积),然后再加3,得9948(人)。
中国有一本数学古书「孙子算经」也有类似的问题:「今有物,不知其数,三三数之,剩二,五五数之,剩三,七七数之,剩二,问物几何?」
答曰:「二十三」
术曰:「三三数之剩二,置一百四十,五五数之剩三,置六十三,七七数之剩二,置三十,并之,得二百三十三,以二百一十减之,即得。凡三三数之剩一,则置七十,五五数之剩一,则置二十一,七七数之剩一,则置十五,即得。」
孙子算经的作者及确实着作年代均不可考,不过根据考证,着作年代不会在晋朝之后,以这个考证来说上面这种问题的解法,中国人发现得比西方早,所以这个问题的推广及其解法,被称为中国剩余定理。中国剩余定理(Chinese Remainder Theorem)在近代抽象代数学中占有一席特别重要的地位。
这种巧妙算法,人们称为鬼谷算,也叫隔墙算,或称为韩信点兵,外国人还称它为“中国剩余定理”。在数论中称"孙子定理".到了明代(1593年),数学家程大位用诗歌一览了这一算法,他写道:
三人同行七十稀,五树梅花廿一枝,
七子团圆月正半,除百零五便得知。
即把3的余数乘70,5的余数乘21,7的余数乘15,而后相加,再减去105,就得答案,
从数论的观点来说,这是壹个特解,而通解是特解+105K,(K为任意整数)
韩信乱点兵口诀:三人同行七十稀,五束梅花二十一,老婆团圆整半月,除百零五便得知。
适用范围是已知总数除以3、5、7后的余数,并且要了解总数的取值范围。然后用除以3的余数乘以70,5的余数乘以21,7的余数乘以15,最后把这三个数的与加起来根据数值范围减(或者加)若干个105(3、5、7的最小公倍数)求解。
比如:100以内的壹个数,除以3余2,除以5余3,除以7余4,则2x70=140,3x21=63,4x15=60,140+63+60=263,263-105=158,158-105=53。