读书人

1000瓶水中觅 出有毒的那瓶毒性一周

发布时间: 2012-11-15 15:16:13 作者: rapoo

1000瓶水中找 出有毒的那瓶,毒性一周后发作,一周内最少需要多少只老鼠

这个题是对bit位的应用,1000接近1024,所以需要10个bit位,对瓶子进行编号,从0到999,这样需要10只老鼠。瓶子的编号分别为:

00000,00000

00000,00001

00000,00010,

00000,00011

00000,00101

00000,00111

。。。。。。

11111,00111

同时给老鼠编号,从1,2,...10,从低位开始,让第n个老鼠喝下第n个bit位为1瓶子中的药水。一周后,若所有的老鼠都没有发病,那么是第一个瓶子有毒,如果有一些老鼠发病,那么从第到高的bit位置成1,其他的还是0。变成整数后,对应的数字即为有毒药水的编号。

2楼huanquan144天前 18:09
不错
1楼qjpcpu4天前 15:36
这个算法真心巧妙啊

读书人网 >互联网

热点推荐