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

砝码称重问题:1449贪心算法高效解决1秒内完成

题目1449砝码称重问题通过高效的贪心算法在1秒内成功解决。给定三种不同重量的砝码\(w_0\)、\(w_1\)和\(w_2\),每种砝码各有一个。本题要求判断是否能够使用这些砝码组合出一个特定的重量\(m\)。通过示例解析,详细展示了如何利用贪心策略快速找到解决方案。

1449 砝码称重
1 秒 131,072 KB 40 分 4 级题
现在有好多种砝码,他们的重量是 w0,w1,w2,... 每种各一个。问用这些砝码能不能表示一个重量为m的东西。

样例解释:可以将重物和3放到一个托盘中,9和1放到另外一个托盘中。

思路:

w进制算法,
如果没有天平,只是这些砝码表示m的话,只需要将m表示成w进制数,然后要求每一位不是0就是1.(每个质量的砝码只有一个,要么放,要么不放)
现在有这个天平,n这个数就是 两个 0 1 组成的数之差
因为有借位问题,相差为1是可以的
即只有下面四种情况:

0-0=0 1-0=1 0-1=w-1(向高位借一后) 1-1=0

分为三大类:

第一大类:相应位数之差为0 1的就很明了

第二大类:相应位数之差为w-1的,借位后的那一位在后面给它加上 1 就好了

第三大类:其余情况就是无解了

代码:

package _51_node.greedy;import java.util.Scanner;public class ex_1449 {/*** 1449 砝码称重* 1 秒 131,072 KB 40 分 4 级题*

* w进制算法,* 如果没有天平,只是这些砝码表示m的话,只需要将m表示成w进制数,然后要求每一位不是0就是1.(每个质量的砝码只有一个,要么放,要么不放)*

* 现在有这个天平,n这个数就是 两个 0 1 组成的数之差* 因为有借位问题,相差为1是可以的* 即只有下面四种情况:** 0-0=0 1-0=1 0-1=w-1(向高位借一后) 1-1=0** 分为三大类:** 第一大类:相应位数之差为0 1的就很明了** 第二大类:相应位数之差为w-1的,借位后的那一位在后面给它加上 1 就好了** 第三大类:其余情况就是无解了** @param args*/public static void main(String[] args) {Scanner cin = new Scanner(System.in);int w = cin.nextInt();int n = cin.nextInt();boolean flag = true;while (n != 0) {if (n % w == 0 || n % w == 1) n /= w;else if ((n + 1) % w == 0) n = (n + 1) / w;else {flag = false;break;}}if (flag) System.out.println("YES");else System.out.println("NO");}
}

转:https://www.cnblogs.com/somliy/p/10043786.html



推荐阅读
  • Oracle培训(三十七)——深入解析Hibernate第三章:实体关联关系映射详解
    在本节Oracle培训中,我们将深入探讨Hibernate第三章的内容,重点讲解实体关联关系映射的详细知识点。首先,回顾了Hibernate的基本概念和映射基础,随后详细分析了不同类型的实体关联关系,包括一对一、一对多和多对多关系的映射方法及其应用场景。通过具体的示例和代码片段,帮助读者更好地理解和掌握这些复杂的映射技术。此外,还讨论了如何优化关联关系的性能,以及常见的问题和解决方案。 ... [详细]
  • 程序连接MySQL数据库的多种方法详解 ... [详细]
  • 在处理Java程序时,中文乱码是一个常见的问题。本文将详细探讨导致中文乱码的原因,并分享有效的解决方案,帮助开发者在实际工作中避免这一问题。通过具体的代码示例和最佳实践,本文旨在提供全面的指导,确保中文字符在不同环境下的正确显示。 ... [详细]
  • 本文通过复旦大学自然语言处理课程中的一个具体案例,详细解析了中文词汇分割技术的实现方法。该案例利用Java编程语言,结合词典和算法模型,展示了如何高效地进行中文文本的词汇分割,为相关研究和应用提供了宝贵的参考。 ... [详细]
  • 力扣——两数之和JAVA
    图片中的方法仅为个人理解,欢迎各位在下方评论 packagecom.shengda.Demo0Likou;importjava.util.HashMap; impor ... [详细]
  • Java包功能详解:初学者指南(附带教学视频解析)
    本文详细解析了Java包的功能及其对初学者的重要性,并通过教学视频进行辅助讲解。文章首先介绍了包的主要作用,包括避免类和方法的命名冲突以及便于管理和组织大量的Java类。随后,逐步引导读者了解工具包中的各个工具类,如StringUtil等,并详细说明了如何配置CLASSPATH环境变量,确保项目中能够正确引用这些类。 ... [详细]
  • Java NIO Buffer详解及其优势与局限性分析 ... [详细]
  • 利用Java开发百度图片爬虫,实现高效下载功能
    为了满足大量图像素材的需求以支持机器学习项目,本文介绍了一种基于Java语言开发的百度图片爬虫工具,该工具能够高效地抓取并下载百度图片中的资源。文章首先展示了爬虫运行的效果图,并详细阐述了其工作原理和技术实现路径,重点解析了如何通过分析百度图片的网页结构来实现精准抓取。此外,还讨论了在实际应用中可能遇到的问题及解决方案。 ... [详细]
  • 通过Apache Commons FileUpload组件,可以根据具体应用需求实现多样化的文件上传功能。在基本应用场景中,开发者可以通过调用单一方法来解析Servlet请求,从而轻松处理文件上传任务。此外,该组件还提供了丰富的配置选项和高级功能,支持大文件上传、多文件并发处理等复杂场景,显著提升了文件上传的效率和可靠性。 ... [详细]
  • 使用Java生成10个随机数填充数组,并通过消息框展示数组元素及求和结果
    本文介绍了如何使用Java语言生成10个随机数并将其存储在一个数组中。随后,通过消息框展示数组的所有元素,并计算这些元素的总和,最终将求和结果一并在消息框中显示。具体实现时,可以通过 `Math.random()` 函数生成0到1000之间的随机数,确保每个数字的随机性和多样性。此外,为了提高代码的可读性和健壮性,建议使用循环结构来简化数组的填充和显示过程。 ... [详细]
  • 本文深入解析了Java编译过程,重点探讨了从源代码到字节码文件的转换机制。通过具体示例,如 `Hello.java` 的编译与反编译过程,详细介绍了 `javap -verbose` 命令的使用方法及其在字节码分析中的重要作用。此外,文章还讨论了字节码文件的结构特点及其在不同应用场景中的实际应用,为开发者提供了宝贵的参考。 ... [详细]
  • 在探讨Java动态代理机制时,本文深入分析了其核心原理与实现方式,并详细讨论了该机制在Spring框架中的应用,特别是在AOP(面向切面编程)中的作用。通过实例解析,读者可以更好地理解如何利用动态代理增强代码的灵活性和可维护性。 ... [详细]
  • 深入解析JDK中的四种随机数生成器
    我们从jdk8说起。主要是四个随机数生成器。神马?有四个? 接下来我们简单说下这几个类的使用场景,来了解其中的细微差别,和a ... [详细]
  • Python初学者入门指南:从基础到实践的全面学习路径本文为Python初学者提供了一条从基础到实践的全面学习路径。特别介绍了Python字典(Dictionary)中的`items()`方法,该方法用于返回字典中所有键值对的视图对象,便于在循环和其他操作中使用。通过实例讲解,帮助读者更好地理解和应用这一重要功能。 ... [详细]
  • CatchThatCowTimeLimit:50002000MS(JavaOthers)MemoryLimit:3276832768K(JavaOt ... [详细]
author-avatar
秀珍冠秋晓雯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有