称球问题的一般解法

本贴最后更新于 2720 天前,其中的信息可能已经事过景迁

本文发表于《CSDN 开发高手》2004 年第 5 期

称球问题相信大家已经很熟悉了,并且已经知道从 12 个球中找出坏球并判断其轻重最多只需要 3 次称量。但如果把球数改变一下,比如说 13 个球,答案又是几次呢?本文将对这一问题进行“深入”分析。为了后面叙述方便,先在这里把一般化后的问题重复一下:

有 m(m≥3)个球,记为 q1、q2、…、qm,其中有且仅有一个坏球,其重量与其他的不同,现使用无砝码的天平进行称量,令 n 为称量次数,问:能确保找到坏球并指出它与好球的轻重关系的 n 的最小值是多少?

先来看理论上要多少次。每次称量有左边轻、平衡和右边轻共 3 种可能的情况,而坏球的可能结果有 q1 轻、q1 重、q2 轻、q2 重、…、qm 轻、qm 重等共 2m 种。因此,根据商农的信息论,此问题的熵就是需要的称量次数,又因为 n 是整数,所以有:

不过理论终归是理论,直接拿到现实生活中往往行不通。一个很简单的情况,4 个球,上面的公式说 2 次称量就够了。但你可以想想办法,反正我是没找到两次解决问题的方案。

那,是理论错了吗?唔,我可不敢怀疑商农,我只敢怀疑我自己。来看看我们错在哪了吧。对 4 个球的情况,第一次称量只有两个可选的方案:

方案 1:q1 放左盘,q2 放右盘。若不平衡(由于对称性,只分析左边轻的情况,下同),则可能的结果还剩 q1 轻和 q2 重,再称一次就能找到坏球;若平衡,则可能的结果还剩 q3 轻、q3 重、q4 轻和 q4 重 4 个,再套用一下商农的定理,此时还要称次。所以方案 1 被否决。

方案 2:q1、q2 放左盘,q3、q4 放右盘。此时天平肯定不会平衡,称量后,可能的结果有 q1 轻、q2 轻、q3 重和 q4 重 4 个。同样的道理,方案 2 也难逃被否决的命运。

在 4 个球这么简单的情况下就撞得满头是包,未免让人难以接受,总结一下经验教训吧,把上面的分析归纳一下并推广到一般情况,就是:整个称量过程中,要达到目的,倒数第 k 次称量前的可能结果数 h,必须满足条件

上面的得出的结论虽然不能让我们找到问题的答案,但却有助于我们确定每次称量的方案,特别是第一次如何做。假设我们计划的称量次数是 n,第一次在左右两盘中各放 x 个球,则保证下面两个不等式同时成立是解决问题的必要条件:

    $2(m-2x) \le 3^{n-1}$  (平衡时)

    $2x \le 3^{n-1}$ (不平衡时)

把这两个不等式稍加变换,就成了下面的样子:

注意到 x 是整数,$3^{n-1}$
显然,在 n 一定的情况下,m 越大,x 的取值范围越小,而当 x 只能取值时,m 继续增大,就会导致 n 次称量找到坏球的计划破产。化简一下,可以得出在 n 一定的情况下 m 的取值范围:。发现了吗?现在 m 的最大值正好比我们最初的结果少了 1。同时此结果也与前面提到的 4 个球的实际情况相符。

但分析了半天,我们只证明了 m 不在取值范围内时,n 次称量不能确保找到坏球。那 m 在取值范围内的时候,肯定能找到吗?答案是肯定的,不过马上证明它有点难,先来看两个简单一点的命题。

**命题 1:**有 A、B 两组球,球的个数分别为 a、b,且 0≤b-a≤1,已知这些球中有且仅有一个坏球,若它在 A 组中,则比正常球轻,在 B 组中则比正常球重。另有一个好球。先使用无砝码的天平称量,令,则可以找到一个称量方案,使得最多经过 n 次称量,就可以找到坏球(此时肯定能指出它与好球的重量关系)。

使用数学归纳法证明如下:

  1. 当 n=1 时,a、b 的取值可能有{0,1}、{1,1}、{1,2}三组,由于还有一个已知的好球,所以不难验证此时命题成立。
  2. 假设当 n=k 时命题也成立。
  3. 当 n=k+1 时。我们将 A、B 两组球分别尽量平均得分为三组,记为 A1、A2、A3、B1、B2 和 B3。不影响一般性,假设这六组球按球数从少到多的排列次序也与前面的顺序一致,且 A1 有球 a1 个。则第一次称量时的称量方案与每组球个数的对应关系如下,其中需要注意的是:在最后两种情况下,必有,否则就与命题的前提不符了。
A1 A2 A3 B1 B2 B3 称量方案
a1 a1 a1 a1 a1 a1 A1、B1 放左盘;A2、B2 放右盘
a1 a1 a1 a1 a1 a1+1 A1、B1 放左盘;A2、B2 放右盘
a1 a1 a1+1 a1 a1 a1+1 A1、B3 放左盘;A3、B1 放右盘
a1 a1 a1+1 a1 a1+1 a1+1 A1、B2 放左盘;A2、B3 放右盘
a1 a1+1 a1+1 a1 a1+1 a1+1 A2、B2 放左盘;A3、B3 放右盘
a1 a1+1 a1+1 a1+1 a1+1 a1+1 A2、B2 放左盘;A3、B3 放右盘

很明显,不管结果是什么,第一次称量之后,问题都能转化为 n=k 时的情形。所以,命题 1 是真命题。

前面已经证明时,n 次称量无法确保找到坏球并指出其轻重关系。但如果此时也有一个已知的好球的话,答案就不一样了,这时 n 次称量就已经足够(命题 2)。仍使用数学归纳法。

  1. 当 n=2 时,m=4,验证一下可知命题成立。 
  2. 假设当 n=k 时命题也成立。 
  3. 当 n=k+1 时。我们把这些球尽量平均的分成三组,则每组球的个数分别为:。第一次称量时,第一组和那个好球放左盘,第三组放右盘。若平衡,问题转化为 n=k 时的情形,不平衡,问题转化为命题 1 的情形。命题成立。

有了前面两个证明作基础,最初的问题就很简单了,再次祭出数据学归纳法。由于 m<5 时的情况有些特殊(考虑只有一个球或两个球的情况),不能作为递推得依据,所以我们从 n=3,也就是 m=5 开始。

  1. 当 n=3 时,m 在 5 和 12 之间(13 的情况已经被排除在外),通过一一验证可知命题成立。 
  2. 假设当 n=k 时命题也成立。 
  3. 当 n=k+1 时,找到一个满足不等式的 x,在天平左右两盘中各放 x 个球。如果天平平衡,问题转化为 n=k 时的情形或命题 2 中的情形;不平衡,则转化为命题 1 的情形。命题成立。

综上所述,称球问题的完整答案是:当球数时,n 次称量时就能确保找到坏球,并指出它与好球的轻重关系;当球数时,n 次称量只能确保找到坏球,而无法指出它与好球的轻重关系。要想指出轻重关系,就可能需要多进行一次称量。但如果此时再有一个好球,就又可以把这次称量省掉了。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1062 引用 • 3455 回帖 • 132 关注
  • 算法
    426 引用 • 254 回帖 • 24 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • V2Ray
    1 引用 • 15 回帖 • 3 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 146 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    19 引用 • 23 回帖 • 750 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    948 引用 • 1460 回帖
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    256 引用 • 1855 回帖
  • 印象笔记
    3 引用 • 21 回帖
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 781 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    4 引用 • 16 回帖 • 201 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    293 引用 • 4496 回帖 • 665 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 241 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 512 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 440 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 563 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 762 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    212 引用 • 358 回帖
  • sts
    2 引用 • 2 回帖 • 245 关注
  • Word
    13 引用 • 41 回帖
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 289 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 2 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 52 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖 • 3 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    415 引用 • 3602 回帖
  • Follow
    4 引用 • 12 回帖 • 14 关注