当我第一次看到这个面试题的时候,也不知道从何处下手,但在别人的提示下,我才明白了!
如果你看到这个题目,能够立即想到2 的 10 次方 = 1024.那你已经知道答案了!
原题的描述是:给你10只实验小鼠,用7天的时间检验1000个瓶子中带有一瓶毒药的瓶子是哪一瓶,小鼠喝了毒药7天后才会死亡,如何编程实现?
这是二进制数的一个应用,如果你不明白白,请看下面简单点的。
用3只来检验8瓶。
小鼠最后的状态只有两种,即:死亡(喝了毒药)和活着(没有喝毒药)。
我们用0 - 7 来给8个瓶子编号,并用二进制表示:
000 第0瓶
001第1瓶
010第2瓶
011第3瓶
100第4瓶
101第5瓶
110第6瓶
111第7瓶
我们让第一只小鼠(红色表示)喝第4、5、6、7瓶,让第二只小鼠(蓝色表示)喝第2、3、6、7瓶,让第三只小鼠喝第1、3、5、7瓶,这样小鼠7天后就只有这八种状态,如果是 第一只活(0),第二只活(0),第三只死(1),那就可以确定是第一瓶,其他的也如此。
2的3次方 = 8,2的10次方 = 1024,所以用10只小鼠可以检验1000个瓶子的。
小鼠的状态可用0(活)、1(死)表示,也就可以用计算机实现。
其实就是进制转换的问题:将二进制转为十进制。
最后输入小鼠的状态,如0000000000,转为十进制 0,则第0瓶有毒。
进制转换代码如下:
public class Base {
/**
* 将数转为任意进制
* @param num
* @param base
* @return
*/
public String baseString(int num,int base){
if(base > 16){
throw new RuntimeException("进制数超出范围,base<=16");
}
StringBuffer str = new StringBuffer("");
String digths = "0123456789ABCDEF";
Stack<Character> s = new Stack<Character>();
while(num != 0){
s.push(digths.charAt(num%base));
num/=base;
}
while(!s.isEmpty()){
str.append(s.pop());
}
return str.toString();
}
/**
* 16进制内任意进制转换
* @param num
* @param srcBase
* @param destBase
* @return
*/
public String baseNum(String num,int srcBase,int destBase){
if(srcBase == destBase){
return num;
}
String digths = "0123456789ABCDEF";
char[] chars = num.toCharArray();
int len = chars.length;
if(destBase != 10){//目标进制不是十进制 先转化为十进制
num = baseNum(num,srcBase,10);
}else{
int n = 0;
for(int i = len - 1; i >=0; i--){
n+=digths.indexOf(chars[i])*Math.pow(srcBase, len - i - 1);
}
return n + "";
}
return baseString(Integer.valueOf(num),destBase);
}
}
转载请标明出处:http://blog.csdn.net/u012027907
分享到:
相关推荐
在该实验中,把一只老鼠从一个无顶大盒子的门放入,在盒子中设置了许多墙,对行进方向形成了多处阻挡。盒子仅有一个出口,在出口处放置一块奶酪,吸引老鼠在迷宫中寻找道路以到达出口。对同一只老鼠重复进行上述实验...
压缩包里详细描述的这个题的逻辑,并且加入了手动输入的功能,运用了线程(但是感觉没啥用),可以供大家参考
java打地鼠实验要求没有实验代码,只有实验要求,高手可以看看做做
基于深度学习的实验鼠行为识别关键技术研究.pdf
比较简单的Jquery悬浮框,鼠标经过的时候向上弹出一个提示云比较简单的Jquery悬浮框,鼠标经过的时候向上弹出一个提示云比较简单的Jquery悬浮框,鼠标经过的时候向上弹出一个提示云
在该实验中,把一只老鼠从一个无顶大盒子的门放入,在盒中设置了许多墙,对行进方向形成了多处阻挡。盒子仅有一个出口,在出口处放置一块奶酪,吸引老鼠在迷宫中寻找道路以到达出口。对同一只老鼠重复进行上述实验,...
代码开放,使用不限,如有问题建议,欢迎及时反馈。 谨此拙作,以抛砖引玉,欢迎批评指正、交流合作! 声明:基于本作二次开发,忽用于商业用途!谢谢合作!! 本文来自:远大航程之网风;原文网址:
医友检验管理系统软件上海康金实验室管理(KJLis2013 V15.2) 是在听取了国内许多检验专家、检验医生的建议和构想,由上海康金信息科技有限公司、具有多年检验科软件经验的高级工程师、于2003年研制开发的软件。...
在程序中使用弹出式菜单,可以让程序更加人性化,操作更加简便。但VB自带的菜单编辑器只能设置窗体顶端的普通菜单。 那么我们如何让我们的程序可以有自己的鼠标右键弹出式菜单呢?本资源包含的源程序代码将为您...
唯一原则:研究员学号唯一、小鼠鼠种编号唯一、同一鼠种下小鼠编号唯一,不同研究员或鼠种下编号可重复!本 程序还可模拟小鼠剪趾编号,可管理合笼实验,并生成三代系谱图。模糊搜索是对所有小鼠的多项信息进行的...
Scratch3.0 10雷神锤打地鼠 程序源代码及素材Scratch3.0 10雷神锤打地鼠 程序源代码及素材Scratch3.0 10雷神锤打地鼠 程序源代码及素材Scratch3.0 10雷神锤打地鼠 程序源代码及素材Scratch3.0 10雷神锤打地鼠 程序源...
苹果鼠标驱动,试了好使,但在MAC下的手式不支持,这点不爽
JAVA实验报告18-“打地鼠”游戏程序设计.pdf
嵌入式实验 使用Qt Designer 编写的打地鼠的代码,可直接运行
在该实验中,把一只老鼠从一个无顶大盒子的门放入,在盒中设置了许多墙,对行进方向形成了多处阻挡。盒子仅有一个出口,在出口处放置一块奶酪,吸引老鼠在迷宫中寻找道路以到达出口。对同一只老鼠重复进行上述实验,...
简单打地鼠游戏,内含源码,通过Handler通信实现地鼠展示,无复杂UI界面,适合新手,方便在此基础上进一步编程,下载后先阅读压缩包中的Readme文件了解详情,学习点:Handler的弱引用的使用
大鼠和小鼠解剖图谱[汇编].pdf
然后又使用一些内存分配技巧使namestr数组用起来好像有多个元素,namelen记录了元素个数。它是怎样工作的?这样是合法的和可移植的吗? 2.8 我听说结构可以赋给变量也可以对函数传入和传出。为什么K&R1却明确说明...
电子-ALIENTEKMINISTM32实验空鼠实验.rar,单片机/嵌入式STM32-F0/F1/F2