首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 互联网 >

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

2012-11-15 
1000瓶水中找 出有毒的那瓶,毒性一周后发作,一周内最少需要多少只老鼠这个题是对bit位的应用,1000接近1024

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
这个算法真心巧妙啊

热点排行