病狗问题

来自计算思维百科
跳转至: 导航搜索
病狗问题1.png

村子中有50个人,每人有一条狗。在这50条狗中有病狗(这种病不会传染)。于是人们就要找出病狗。每个人可以观察其他的49条狗,以判断它们是否生病,只有自己的狗不能看。观察后得到的结果不得交流,也不能通知病狗的主人。主人一旦推算出自己家的是病狗就要枪毙自己的狗,而且每个人只有权利枪毙自己的狗,没有权利打死其他人的狗。第一天,第二天都没有枪响。到了第三天传来一阵枪声,问有几条病狗,如何推算得出?

解决方案

方案1-假设法

假设有1条病狗,病狗的主人会看到其他狗都没有病,那么就知道自己的狗有病,所以第一天晚上就会有枪响.因为没有枪响,说明病狗数大于1.
假设有2条病狗,病狗的主人会看到有1条病狗,因为第一天没有听到枪响,是病狗数大于1,所以病狗的主人会知道自己的狗是病狗,因而第二天会有枪响。既然第二天也没有枪响,说明病狗数大于2。
由此推理,因为第三天枪响,则有3条病狗。

运用的计算思维

假设法通过从小范围天数逐步推算病狗的数量,进而找到天数和病狗的数量的关系,轻松推算出病狗的数量,运用了学习的计算思维。

参考资料

《世界经典逻辑智力游戏550例子》  元坤 主编  当代世界出版社