zoukankan
html css js c++ java
小白鼠问题(海明码)
小白鼠问题(海明码)
同学问了一道智力题:30瓶水,其中有一瓶毒药,小白鼠喝了毒药之后一天会死,求只有一天时间,用最少的小白鼠找出毒药?
很简单的我就想到了海明码:
数位
数值
C1
00001
C2
00010
C4
00100
C8
01000
C16
10000
(C1=A1⊕A3⊕A5...⊕A29)
(C2=A2⊕A3⊕A5...⊕A30)
(C4=A4⊕A5⊕A5...⊕A30)
(C8=A8⊕A9⊕A10...⊕A30)
(C16=A16⊕A17⊕A518.⊕A30)
我们将A看作水,将水从1编号到30。C作为混合水,也就是将对应编号的水混合成5瓶水,对应C16C8C4C2C1。每瓶水用一只小白鼠实验(残忍),哪只死亡,哪只对应编号为1。例如,C8,C4死亡,那么对应二进制数为0110,也就是十进制12,代表12号水有毒。
如果推广到n瓶水呢?当:
$$2^x-1>=n$$
时,可以满足需求。即:
$$x>=log_2 (n+1)$$
所需小白鼠数量为大于等于以2为底n+1的对数的最小整数。
但是这个是使用一切情况吗?当n=1时,x=1。但是实际上,一杯水不需要验证,他就是有毒的。所以我发现当:
$$n=2^x$$
时是一种特殊情况。例如,当n=32时,我可以把标号为32的水拿出,剩余31瓶可以按照如上方法求出答案,只是多出一种00000的情况,说明前31瓶水都无毒。那么拿出的32号水肯定有毒!
所以正确的公式应为:
$$2^x>=n$$
即:
$$x>=log_2 n$$
所需小白鼠数量为大于等于以2为底n的对数的最小整数。这是推广到n时的正解。
查看全文
相关阅读:
spring data jpa删除的使用方式
javax.persistence.TransactionRequiredException: No transactional EntityManager available
java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result异常的解决方法
JS比较两个数组是否相等 是否拥有相同元素
HttpSession的线程安全问题及注意事项
easyui datagrid editor onBeforeEdit事件下使用getEditor和getEditors失效
JQuery easyUi datagrid 中 editor 动态设置最大值最小值
kaptcha验证码组件使用简介
ohasd failed to start: Inappropriate ioctl for device
web报表工具FineReport常见的数据集报错错误代码和解释
原文地址:https://www.cnblogs.com/kingbk/p/8675228.html
最新文章
HDU 1695 GCD 容斥
poj 1845 Sumdiv 约数和定理
奇怪的数学公式系列
Codeforces Educational Codeforces Round 5 E. Sum of Remainders 数学
Codeforces Educational Codeforces Round 5 D. Longest k-Good Segment 尺取法
Codeforces Educational Codeforces Round 5 C. The Labyrinth 带权并查集
Codeforces Educational Codeforces Round 5 B. Dinner with Emma 暴力
Codeforces Educational Codeforces Round 5 A. Comparing Two Long Integers 高精度比大小,模拟
hdu 4859 海岸线 最小割
《山桂~少女与少女等待秋日再会》
热门文章
hdu 4858 项目管理 分块
hdu 4857 逃生 拓扑排序
Codeforces Round #181 (Div. 2) C. Beautiful Numbers 排列组合 暴力
Codeforces Round #181 (Div. 2) B. Coach 带权并查集
Codeforces Round #181 (Div. 2) A. Array 构造
Codeforces Round #180 (Div. 2) D. Fish Weight 贪心
Codeforces Round #180 (Div. 2) C. Parity Game 数学
Codeforces Round #180 (Div. 2) B. Sail 贪心
Java实现主线程等待子线程
动态修改datagrid中的numberbox的最大值和最小值
Copyright © 2011-2022 走看看