小白鼠试药逻辑题

题目: 100瓶药瓶只有一瓶有毒,如果小白鼠吃毒药2小时死亡,请问2小时内最少需要多少只小白鼠才能试药出来?

分析:先从4瓶找灵感,需要几只?这种其实是肯定需要一只小白鼠喝多瓶药的情况了,4瓶,即 0,1,2,3,想到了这像什么?是不是就是二进制 00, 01, 10, 11?代表的意思就是第 0 瓶无老鼠喝,第 1 瓶第一只老鼠,第 2 瓶第二只老鼠喝,第 3 瓶两只老鼠喝?这样每种喝药的情况是不是就可以对应每一瓶?不就是两只老鼠就可以了?同理100只,1000只药瓶不也是这样?对应这个数字所代表的二进制。

面试时未想出来很可惜.....

总结,遇到数字大的情况下,先分析小的,再查找规律,写代码也一样,先实现一个基本的,再维护可扩展的,一步一步健壮的代码便完成了。

转载于:https://juejin.im/post/5bcdf99af265da0abe273615

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值