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

leetcode:871.最低加油次数【以前pat做过+最大堆+贪心】

分析注意,加油站是沿途,所以target一定在所有加油站的右方然后,油的效果是累计的,根跳跃游戏不一样,不能

在这里插入图片描述

分析

注意,加油站是沿途,所以target一定在所有加油站的右方
然后,油的效果是累计的,根跳跃游戏不一样,不能走一下贪心一下
要用一个大根堆维护之前的加油中最大的加油量来贪心
思想就是,走到某个地方,如果去到之后的油是负数,那么就找之前存着的加油站中的最大值加一下,计算一次
如果加完之前的所有都到不了就凉凉
然后把当前的加油站放入大根堆(奖励),并更新上一个点prev
注意,target是最后一个curr,也要算上去

Ac code

class Solution:def minRefuelStops(self, target: int, startFuel: int, stations: List[List[int]]) -> int:# 加油的效果是累计的# 所以用大根堆&#xff0c;每次取最大的加油来贪心&#xff08;大根堆&#xff09;# 如果取完还不能到目前点&#xff0c;返回-1ans, nowFuel, prev, pq &#61; 0, startFuel, 0, []stations.sort()n &#61; len(stations)# 多一个target的位置# 沿途右加油站&#xff0c;所以target一定在最右边for i in range(n &#43; 1):# 当前要去的位置curr &#61; stations[i][0] if i < n else targetnowFuel -&#61; curr - prev# 不够油的&#xff0c;贪心加油while nowFuel < 0 and pq:nowFuel &#43;&#61; -heappop(pq)ans &#43;&#61; 1# 加完开始去不到if nowFuel < 0:return -1# 若能去到&#xff0c;放进大根堆if i < n:heappush(pq, -stations[i][1])# 更新prevprev &#61; currreturn ans

总结

贪心 &#43; 大根堆
非常classic

20220905踩踩

这个是延迟支付的思想
去得到的先放进pq当备胎
然后产生危机的时候在备胎里面选一个加油最大的

java

class Solution {public int minRefuelStops(int target, int startFuel, int[][] stations) {// b - a > 0就交换&#xff0c;所以是大根堆PriorityQueue<Integer> pq &#61; new PriorityQueue<Integer> ((a, b) -> b - a);int ans &#61; 0, prev &#61; 0, fuel &#61; startFuel;int n &#61; stations.length;// fuel是累计的for (int i &#61; 0; i <&#61; n; i&#43;&#43;) {int curr &#61; i < n ? stations[i][0] : target;fuel -&#61; curr - prev;while (fuel < 0 && !pq.isEmpty()) {fuel &#43;&#61; pq.poll();ans&#43;&#43;;}if (fuel < 0) {return -1;}if (i < n) {pq.offer(stations[i][1]);prev &#61; curr;}}return ans;}
}

java总结

// b - a > 0就交换&#xff0c;所以是大根堆
PriorityQueue pq &#61; new PriorityQueue ((a, b) -> b - a);
b - a这个式子的意思是&#xff0c;b - a > 0就交换&#xff0c;所以是大根堆
反之&#xff0c;如果改成a - b&#xff0c;如果a - b > 0就交换&#xff0c;就是小根堆
pq.isEmpty()
pq.poll()
pq.offer()


推荐阅读
  • 在Java项目中,当两个文件进行互相调用时出现了函数错误。具体问题出现在 `MainFrame.java` 文件中,该文件位于 `cn.javass.bookmgr` 包下,并且导入了 `java.awt.BorderLayout` 和 `java.awt.Event` 等相关类。为了确保项目的正常运行,请求提供专业的解决方案,以解决函数调用中的错误。建议从类路径、依赖关系和方法签名等方面入手,进行全面排查和调试。 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • 本文探讨了 Java 中 Pair 类的历史与现状。虽然 Java 标准库中没有内置的 Pair 类,但社区和第三方库提供了多种实现方式,如 Apache Commons 的 Pair 类和 JavaFX 的 javafx.util.Pair 类。这些实现为需要处理成对数据的开发者提供了便利。此外,文章还讨论了为何标准库未包含 Pair 类的原因,以及在现代 Java 开发中使用 Pair 类的最佳实践。 ... [详细]
  • 探索偶数次幂二项式系数的求和方法及其数学意义 ... [详细]
  • HBase Java API 进阶:过滤器详解与应用实例
    本文详细探讨了HBase 1.2.6版本中Java API的高级应用,重点介绍了过滤器的使用方法和实际案例。首先,文章对几种常见的HBase过滤器进行了概述,包括列前缀过滤器(ColumnPrefixFilter)和时间戳过滤器(TimestampsFilter)。此外,还详细讲解了分页过滤器(PageFilter)的实现原理及其在大数据查询中的应用场景。通过具体的代码示例,读者可以更好地理解和掌握这些过滤器的使用技巧,从而提高数据处理的效率和灵活性。 ... [详细]
  • 设计实战 | 10个Kotlin项目深度解析:首页模块开发详解
    设计实战 | 10个Kotlin项目深度解析:首页模块开发详解 ... [详细]
  • 在Python多进程编程中,`multiprocessing`模块是不可或缺的工具。本文详细探讨了该模块在多进程管理中的核心原理,并通过实际代码示例进行了深入分析。文章不仅总结了常见的多进程编程技巧,还提供了解决常见问题的实用方法,帮助读者更好地理解和应用多进程编程技术。 ... [详细]
  • 如何使用 com.jme3.input.FlyByCamera 构造函数及其代码示例详解 ... [详细]
  • Java集合框架特性详解与开发实践笔记
    Java集合框架特性详解与开发实践笔记 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • 手指触控|Android电容屏幕驱动调试指南
    手指触控|Android电容屏幕驱动调试指南 ... [详细]
  • 基址获取与驱动开发:内核中提取ntoskrnl模块的基地址方法解析
    基址获取与驱动开发:内核中提取ntoskrnl模块的基地址方法解析 ... [详细]
  • 在处理大图片时,PHP 常常会遇到内存溢出的问题。为了避免这种情况,建议避免使用 `setImageBitmap`、`setImageResource` 或 `BitmapFactory.decodeResource` 等方法直接加载大图。这些函数在处理大图片时会消耗大量内存,导致应用崩溃。推荐采用分块处理、图像压缩和缓存机制等策略,以优化内存使用并提高处理效率。此外,可以考虑使用第三方库如 ImageMagick 或 GD 库来处理大图片,这些库提供了更高效的内存管理和图像处理功能。 ... [详细]
  • 本书详细介绍了在最新Linux 4.0内核环境下进行Java与Linux设备驱动开发的全面指南。内容涵盖设备驱动的基本概念、开发环境的搭建、操作系统对设备驱动的影响以及具体开发步骤和技巧。通过丰富的实例和深入的技术解析,帮助读者掌握设备驱动开发的核心技术和最佳实践。 ... [详细]
  • 本文深入探讨了RecyclerView的缓存与视图复用机制,详细解析了不同类型的缓存及其功能。首先,介绍了屏幕内ViewHolder的Scrap缓存,这是一种最轻量级的缓存方式,旨在提高滚动性能并减少不必要的视图创建。通过分析其设计原理,揭示了Scrap缓存为何能有效提升用户体验。此外,还讨论了其他类型的缓存机制,如RecycledViewPool和ViewCacheExtension,进一步优化了视图复用效率。 ... [详细]
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社区 版权所有