一道经典IBM面试题 自解
来源:互联网 发布:新网互联域名证书生成 编辑:程序博客网 时间:2024/05/17 20:14
村子中有50个人,每人有一条狗。
在这50条狗中有病狗(这种病不会传染)。于是人们就要找出病狗。每个人可以观察其他的49条狗,以判断它们是否生病(如果有病一定能看出来),只是自己的狗不能看。观察后得到的结果不得交流,也不能通知病狗的主人。
主人一旦推算出自己家的是病狗就要枪毙自己的狗(发现后必须在一天内枪毙),而且每个人只有权利枪毙自己的狗,没有权利打死其他人的狗。第一天大家全看完了,但枪没有响,第二天仍没有枪响。
到了第三天传来一阵枪声,问村里共有几条病狗,如何推算得出?
..
.
.
.
.
.
.
..
..
..
..
.
.
..
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
..
.
.
.
.
.
.
.
..
.
答案:3只狗有病:
1。如果1只有病,那么第一天就会有枪响;
2。根据第一天没枪响,可推断出:至少有2只狗有病。但是,如果刚好2个,则其主人可根据自己看到的一个有病的狗,推断出自己的狗也有病;
3。如果前2天都没枪响,那大家都可推断出:至少有3只狗有病。同上,3个主人可根据自己看到的2个有病的狗,推断出自己的狗有病。
总结:每个人会根据自己看到的有病狗的数量决定会在哪一天准备开枪,即,如果看到N个有病狗,而过了N天仍没人开枪,那自然推断出自己的狗有病!
- 一道经典IBM面试题 自解
- IBM经典面试题
- IBM经典面试题
- IBM经典面试题
- 一道经典的面试题
- 一道java经典面试题
- IBM一道面试题及解答
- 解一道面试题
- 华为的一道经典面试题详解
- 一道经典SQL面试题及答案
- 一道经典的JAVA面试题
- 一道经典的java面试题分析
- 关于索引的一道经典面试题
- 关于fork()的一道经典面试题
- 一道经典面试题---运动员跳水比赛结果
- 一道经典的sql面试题
- 一道很经典的多线程面试题
- 面试题 自解
- C# 实现保留两位小数的方法
- 关于jquery插件
- mate 虚拟机
- C/S(client/server )客户服务器模式 B/S(browser/server)浏览器服务器模式
- 从头开始编写操作系统(4) 第3章:引导加载器
- 一道经典IBM面试题 自解
- C#中写Excell
- Word/WPS中页码从指定的页面开始插入方法
- matlab中的数据类型和显示精度
- Android开发环境搭建全程演示(jdk+eclip+android sdk)
- IO 输入与输出(3) -- 节点流之五ByteArrayInputStream和ByteArrayOutputStream类
- 2011 3月微博
- Acm 母函数
- Struts2的国际化支持