2 道很有意思的进制题

本贴最后更新于 2586 天前,其中的信息可能已经物是人非
  1. 一共有 10 只老鼠,1000 只水杯,杯子里都盛着水,只有一个杯中是有毒的液体,这种毒 液老鼠喝下去以后,一个星期就会死掉。现在要求使用这 10 只老鼠,在一个星期之内找出盛着毒液的杯子。

分析一下,这道题目其实是一道和二进制相关的题目。由于只能在一个星期内完成任务,那就说明不能进行重复的实验。这样的话,由于 10 只老鼠在一个星期以后的状态只能是死亡或者存活两种状态,根据乘法原理,我们知道,10 个单位的两种状态,可能出现的所有可能是 2^10 = 1024。足够编码 1000 个杯子了。也就是说,我们现在的任务是把 1000 个杯子 与 10 只老鼠的死和活的组合一一对应起来。如果把 1 到 1000 表示成二进制,那么答案就很明显了。

将 1 到 1000 共一千个数,都转换成二进制编码。对于数字 A,如果它的二进制的最低位 是 1,那么就让 1 号老鼠喝一点这个杯子里的液体,如果是 0 就不喝。A 的二进制的倒数第二低位如果是 1,那么编号为 2 的老鼠就喝,否则不喝。依次类推。直到最高位如果是 1,那么编号为 10 的老鼠就喝,否则该老鼠不喝。一个星期以后观察结果,如果编号为 x 的老鼠死掉 了,那么就从低向高数 x 位,在那个位置上标 1,其他的位置标 0。例如,如果只有 2 号和 4 号 老鼠死掉了,那么记录的结果就是“00 0000 1010”,这样一个二进制数。把它转成十进制是 10,这就意味着 10 号杯子里装的是毒液,其他杯子则是水。

  1. 有一架天平,它有 20 个砝码,这 20 个砝码的重量分别为 1,3,9,27···3^19。只要被称的物品的重量为位于区间 [1,(3^20−1)/2] 的整数,就可以使用这架天平进行称量。假设物品一直放在天平的左边,现在给出每个物品的重量,请打印出称量的方案。输出格式为两组数字,第一组代表天平左边要放的砝码,第二组代表天平右边要放的砝码。这两组数中间用空格隔开。每一组内部的数使用逗号隔开。如果天平的某一边不需要放砝码,那就打印 empty。
    例如,输入是 9,输出是 empty 9,代表左边不需要额外的砝码,而右边需要放一个重量为 9 的砝码。 输入是 4,输出是 empty 1,3。

从最简单的情况入手进行分析。比如说 1,那右边只要放 1 就可以。如果是 2,我们可以用左边放 1,右边放 3 这样的方案代替。3,右边只要放 3。4,右边放 1 和 4。到了 5,由于不能再使用 3-1 去凑一个 2 了,所以唯一的方案是左边放 1,3,右边放 9。同样,6,也只好用 9-3 来凑。我们来分析一下这个规律。

4 的三进制是 11,代表了 1 * 3 ^ 1 + 1,5 的三进制是 12,代表了 1 * 3 ^ 1 + 2 * 3^0,6 的三进制是 20,代表了 2 * 3^1 + 0 * 3^0。由于我们手里的砝码是 3^0, 3^1, 3^2……,也就是说,如果目标数字的各个位置上都是 1,那我们直接就能组合出来,而如果第 n 位上是 2,就必须使用 3^(n+1) - 3^n 来凑这个数。也就是说,我们要在天平的左右两边各加上一个 3^n,才能保持平衡。这样就把低一位上的 2,消除成了高一位上的 1。

好了。有了这个算法,我们就可以写出程序了。

public int[][] solve(int x) {
    int pl = 0, pr = 0;
    int poise = 1, r;
    final int LEFT = 0, RIGHT = 1;
    int[][] result = new int[2][20];

    while (x > 0) {
        r = x % 3;
        if (r == 2) {
            result[LEFT][pl++] = poise;
            x = (x + 1) / 3;
        }   
        else if (r == 1) {
            result[RIGHT][pr++] = poise;
            x = x / 3;
        }
        else
            x = x / 3;

        poise *= 3;
    }

    return result;
}
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3169 引用 • 8208 回帖
  • 老鼠
    1 引用

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 137 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    4 引用 • 91 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    281 引用 • 716 回帖
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    76 引用 • 37 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 555 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    21 引用 • 37 回帖 • 523 关注
  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 12 关注
  • Mobi.css

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

    1 引用 • 6 回帖 • 714 关注
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    923 引用 • 936 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • TGIF

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

    285 引用 • 4482 回帖 • 658 关注
  • 智能合约

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

    1 引用 • 11 回帖 • 7 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    7017 引用 • 31714 回帖 • 220 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 446 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖 • 5 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    71 引用 • 1737 回帖 • 2 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 2 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    106 引用 • 152 回帖
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    7 引用 • 26 回帖
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 474 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 48 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    91 引用 • 751 回帖
  • Sillot

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

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

    主仓库地址:Hi-Windom/Sillot

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

    注意事项:

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