面试算法智力题

目录 毒药问题,博弈论,蚂蚁问题,换瓶子问题

 

1. 1000瓶毒药里面只有1瓶是有毒的,毒发时间为24个小时,问需要多少只老鼠才能在24小时试出那瓶有毒。

 

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

老鼠用  a ,b ,c ,d ,e ,f ,g ,h ,i , j ,表示

第0号瓶:00000,00000

第1号瓶:00000,00001      a

第2号瓶:00000,00010      b     

第3号瓶:00000,00011       a   b

第4号瓶:00000,00101     a        c

第5号瓶:00000,00111     a   b   c

。。。。。。

第999号瓶:11111,00111   a    b   c        f g  h  i  j 

同时给老鼠编号,从1,2,...10,从低位开始,让第n个老鼠喝下第n个bit位为1瓶子中的药水。24小时

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值