`
xiaoya629
  • 浏览: 28322 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

【java算法】买苹果

    博客分类:
  • java
阅读更多

题目:有600个苹果,要求分装在10个盒子中。对于顾客要求的任意苹果数都可以通过此10个盒子进行组合得到。

分析:1、首先要设计10个盒子所装苹果的数目。由二进制与十进制的转换可知,2的倍数相加可以的到一切十进制数。所以如果想使用有限的数字组合得到一定范围内的所有数字必是以2的倍数进行设计的。所以,可知十个盒子里的苹果数应该是1,2,4,8,16,32,64....。

2、有10个盒子,每个盒子对应一位二进制。例如100,100的二进制表示方式1100100,他应该取:4+32+64这三个盒子,也就是位数为1的那几个。同时,由于10位二进制能表示的最大数是1023(也就是相当于盒子相加之和),但要以600为总数,所以只能取9位,9位能表示的最大数是511。所以最后一个盒子应该装600-511=89。所以盒子里所装苹果应该是1,2,4,8,16,32,64,128,256,89。

3、当顾客给出要求的苹果数后,如果小于511,就可以转为二进制,翻转,取1对应的盒子即可。如果大于511,就要先减去89,再转为二进制,翻转取盒,最后加上第十个盒子。

实现代码如下:

分享到:
评论

相关推荐

    基于Java的图像去噪算法设计与实现

    基于Java的图像去噪算法设计与实现 包含去光斑_去雾_去暗_去水印算法

    基于Java与协同过滤算法的电影推荐系统设计与实现

    基于Java与协同过滤算法的电影推荐系统设计与实现

    基于java的leetcode刷题与复习指南算法模板代码

    基于java的leetcode刷题与复习指南算法模板代码

    基于java与粒子群优化算法PSO的自动组卷考试系统设计与实现

    基于java与粒子群优化算法PSO的自动组卷考试系统设计与实现

    基于java的遗传算法设计与实现

    基于java的遗传算法设计与实现

    基于java的粒子群算法优化神经网络设计与实现

    基于java的粒子群算法优化神经网络设计与实现

    基于Java与Android的百度地图运动轨迹纠偏与去噪设计实现

    基于Java与Android的百度地图运动轨迹纠偏与去噪设计实现

    Java 经典算法问题:五只猴子分桃子解题源码.rar

    Java 经典算法问题:五只猴子分桃子解题源码,此问题描述为:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。  第二只猴子把剩下的桃子又...

    JAVA上百实例源码以及开源项目源代码

     [MonthMaker.java] 月份表算法类  [Pallet.java] 调色板,统一配色类 Java扫雷源码 Java生成自定义控件源代码 2个目标文件 Java实现HTTP连接与浏览,Java源码下载 1个目标文件 摘要:Java源码,网络相关,HTTP ...

    JAVA上百实例源码以及开源项目

     [MonthMaker.java] 月份表算法类  [Pallet.java] 调色板,统一配色类 Java扫雷源码 Java生成自定义控件源代码 2个目标文件 Java实现HTTP连接与浏览,Java源码下载 1个目标文件 摘要:Java源码,网络相关,HTTP ...

    java开源包11

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包6

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包4

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包101

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包9

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包5

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包8

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包10

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    java开源包3

    Blister是一个用于操作苹果二进制PList文件格式的Java开源类库(可用于发送数据给iOS应用程序)。 重复文件检查工具 FindDup.tar FindDup 是一个简单易用的工具,用来检查计算机上重复的文件。 OpenID的Java客户端...

    基于Java的新闻推荐系统设计与实现

    基于Java的新闻推荐系统设计与实现

Global site tag (gtag.js) - Google Analytics