2 道很有意思的进制题

本贴最后更新于 2828 天前,其中的信息可能已经物是人非
  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 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3194 引用 • 8214 回帖
  • 老鼠
    1 引用

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖 • 1 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 22 关注
  • 自由行
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 319 关注
  • SSL

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

    70 引用 • 193 回帖 • 417 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 53 关注
  • Solo

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

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

    1439 引用 • 10067 回帖 • 491 关注
  • SOHO

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

    7 引用 • 55 回帖 • 2 关注
  • 国际化

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

    8 引用 • 26 回帖
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 159 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖 • 1 关注
  • 反馈

    Communication channel for makers and users.

    126 引用 • 929 回帖 • 266 关注
  • Visio
    1 引用 • 2 回帖 • 1 关注
  • Typecho

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

    12 引用 • 67 回帖 • 444 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 544 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 7 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖 • 1 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 18 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 383 关注
  • gRpc
    11 引用 • 9 回帖 • 89 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 2 关注
  • Love2D

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

    14 引用 • 53 回帖 • 545 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 201 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 278 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    425 引用 • 1250 回帖 • 599 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注