热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

砝码称重问题二

题目描述有一组砝码,重量互不相等,分别为m1、m2、m3……mn;它们可取的最大数量分别为x1、x2、x3……xn。现要用这些砝码去称物体的重量,问能称出多少种不同的重量。现在给你

题目描述

有一组砝码,重量互不相等,分别为m1、m2、m3……mn;它们可取的最大数量分别为x1、x2、x3……xn。
现要用这些砝码去称物体的重量,问能称出多少种不同的重量。
现在给你两个正整数列表w和n, 列表w中的第i个元素w[i]表示第i个砝码的重量,列表n的第i个元素n[i]表示砝码i的最大数量。  i从0开始                   
请你输出不同重量的种数。
如:w=[1,2], n=[2,1], 则输出5(分析:共有五种重量:0,1,2,3,4)

解题

参考智力题砝码称重问题,有一个这样的样例:砝码重量:[1,3,9],个数:[1,1,1]可以称出1到13内的质量

然后自己死活写不出来,网上整理了砝码称重的智力题,又发现说这个是背包问题,就做了背包问题相关题目

PythonTip解题报告中给了下面的程序:

技术分享

根据输出结果可以看出:本题的砝码称重,砝码必须放在同一侧,砝码一侧,重物一侧。在上面的测试环境中可以通过,网上看到的砝码称重大部分就是这样的称重

上面程序的原理:

定义集合set:表示能够称出的重物重量

set初始化:所有砝码的重量

 遍历所有种类的砝码:

遍历该种类砝码的数量:

可以称出新的重物质量 = 集合内的值 减去 砝码的重量*砝码的个数

循环结束后集合内的值就是答案了

   根据果壳 中的讲解,可以发现上面的过程没有 -a 的情况,只有 0 a的情况,也就是说砝码必须都放在同一侧

 初始集合值是0:

length_n=len(w)
S=set([])
S.add(0)
for i in range(length_n):
    temp_S=S.copy()
    for s in temp_S:
        j=1
        while j<=n[i]:
            S.add(s+j*w[i])
            j+=1
#print S 
print len(S)

Java

    public int backPack2(int[]A,int []B){
        int total = 0;
        for(int i=0;i)
            total +=A[i]*B[i];
        TreeSet set = new TreeSet();
        set.add(total);
        for(int i=0;i){
            Object[] setCopy = set.toArray();
            for(Object s:setCopy){
                int j = 1;
                while(j<=B[i]){
                    set.add(((Integer)s-j*A[i]));
                    j++;
                }
            }
        }
        for(Integer s:set){
            System.out.print(s+" ");
        }
        return set.size();
    }

下面考虑砝码可以放在天平的不同侧的情况

参考:http://www.tuicool.com/articles/yqYjM3

讲解见注释

    /**
     * A[i] 第i个砝码的重量
     * B[i] 第i个砝码的数量
     * @param A
     * @param B
     * @return
     */
    public int backPack3(int[]A,int []B){
        int total = 0;
        for(int i=0;i)
            total +=A[i]*B[i];
        boolean dp[] = new boolean[total+1]; // dp[i] = true 表示可以称出质量为 i 的重物 
        dp[0] = true; 
        for(int i=0;i// 砝码重量
            for(int j = 0;j<=B[i];j++){// 对 第 i个砝码遍历其种类
                for(int s=total;s>=A[i];s--){ // 砝码的总重量开始遍历,为什么? total -- A[i] 的质量是否能够称出 能否称出体现着 s-A[i]能否称出
                    if(dp[s - A[i]]) // dp[s - A[i]] = true 就是可以称出 s - A[i]的重物,也就是可以称出 s - A[i] + A[i] 的重物 
                        dp[s] = true;
                }
            }
        }
        int count = 0;
        for(int i = 0;i){
            if(dp[i]){
                System.out.print(i+" ");
                count++;
            }
        }
        return count;
    }

砝码称重问题二


推荐阅读
  • Python 内存管理机制详解
    本文深入探讨了Python的内存管理机制,涵盖了垃圾回收、引用计数和内存池机制。通过具体示例和专业解释,帮助读者理解Python如何高效地管理和释放内存资源。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 如何清除Chrome浏览器地址栏的特定历史记录
    在使用Chrome浏览器时,你可能会发现地址栏保存了大量浏览记录。有时你可能希望删除某些特定的历史记录而不影响其他数据。本文将详细介绍如何单独删除地址栏中的特定记录以及批量清除所有历史记录的方法。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 解决TensorFlow CPU版本安装中的依赖问题
    本文记录了在安装CPU版本的TensorFlow过程中遇到的依赖问题及解决方案,特别是numpy版本不匹配和动态链接库(DLL)错误。通过详细的步骤说明和专业建议,帮助读者顺利安装并使用TensorFlow。 ... [详细]
  • 探索新一代API文档工具,告别Swagger的繁琐
    对于后端开发者而言,编写和维护API文档既繁琐又不可或缺。本文将介绍一款全新的API文档工具,帮助团队更高效地协作,简化API文档生成流程。 ... [详细]
  • 本文探讨了在构建应用程序时,如何对不同类型的数据进行结构化设计。主要分为三类:全局配置、用户个人设置和用户关系链。每种类型的数据都有其独特的用途和应用场景,合理规划这些数据结构有助于提升用户体验和系统的可维护性。 ... [详细]
  • Linux中的yum安装软件
    yum俗称大黄狗作用:解决安装软件包的依赖关系当安装依赖关系的软件包时,会将依赖的软件包一起安装。本地yum:需要yum源,光驱挂载。yum源:(刚开始查看yum源中的内容就是上图 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 气象对比分析
    本文探讨了不同地区和时间段的天气模式,通过详细的图表和数据分析,揭示了气候变化的趋势及其对环境和社会的影响。 ... [详细]
  • Windows 7 64位系统下Redis的安装与PHP Redis扩展配置
    本文详细介绍了在Windows 7 64位操作系统中安装Redis以及配置PHP Redis扩展的方法,包括下载、安装和基本使用步骤。适合对Redis和PHP集成感兴趣的开发人员参考。 ... [详细]
  • 本文探讨了如何利用NFC技术,将存储在Android手机中的患者信息安全高效地传输到台式计算机。重点介绍了适用于医院场景的NFC USB读卡器(如ACR122U)的应用方法。 ... [详细]
  • 本文探讨了如何解决PHP文件无法写入本地文件的问题,并解释了PHP文件中HTML代码无效的原因,提供了一系列实用的解决方案和最佳实践。 ... [详细]
author-avatar
冰weiter
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有