当前位置: 首页 > news >正文

LeetCode-871 最低加油次数

重启力扣每日一题系列!

因为过去两个月里掉粉掉的好严重,我想大抵是因为更新的频率不如上半年了,如果我重启了每日一题系列那岂不是至少是每日一更☝🤓?

也不是每天都更,我有两不更,特难的就不更了,打算去算法岗的小伙伴自己琢磨去;特简单的也不更了,那么简单更出来岂不是拉低我的平均水准;麻烦的不更,太麻烦了费我时间;方便的也不更,直接调库就好了……

这次重启跟之前的也不一样了,之前几乎每一题我都会自己作图,包括动图,这很花时间,通常是从早上做到下午,做完累了休息一下就到晚上了,一天下来光力扣了。

所以这次化简了,指提供思路和C++示例代码,咱来个力扣每日一题极速版。

废话说多了,我们直接看看今天的题目。

这题其实跟昨天的题是同一个系列的,但是做法上面天差地别。

先做个阅读理解,简单来说就是我们一开始有一些汽油,每升汽油可以走一公里,某些公里处有加油站,我们可以加一次油,问我们最少加几次油可以走到目的地。

比较容易想到的是暴力解法,我们直接模拟,每到一个加油站我们都开两个分叉,也就是加油或者不加油,每个能到目的地的分支我们都记录下加了几次油,选着最少的加油数返回即可。

不过这是困难题,想都不用想也可以知道会超时(没试过,说不准呢?)

看看这可怕的数据范围。

不过知道暴力解法之后就是成功的第一步了,我们要做的就是优化暴力解法,这也是正常的解题过程。

因为我们要最少的加油数,所以我们要尽可能的少加油,但是少加油之后错过加油站了怎么办呢?

现实中你会错过她,但是在代码里我们不会再错过了,没有对象咱就new一个嘛。

我们每经过一个加油站,我们都把油搬上车,等到没油了我们再加一次油,因为要尽可能少加油,所以每次我们都加油数最多的那一桶油,这样就不会错过了。

代码中实现就是我们先行驶,能跑多远跑多远,然后把经过的加油站的汽油都先放到一个容器里,因为我们每次要取的是最大的值,所以这个容器我选择优先队列,也就是大顶堆。

如果我们没跑过目的地,那么我们从大顶堆里掏出一个汽油,然后再接着跑,反复循环,直到我们跑到了目的地或者是没油了,一滴都没有了。

具体可以参考下面的代码。

class Solution {
public:int minRefuelStops(int target, int startFuel, vector<vector<int>>& stations) {priority_queue<int> cache;      // 存放沿途的汽油int res = 0;                    // 加油次数int cur = 0, index = 0;         // 当前路程,stations索引(途径加油站个数)while(cur < target && startFuel > 0){   // 不到目的地 && 还有汽油cur += startFuel;           // 前进startFuel = 0;              // 清零汽油while(index < stations.size() && stations[index][0] <= cur){    // 将经过的汽油记录在大顶堆中cache.push(stations[index][1]);index++;}if(cur < target && !cache.empty()){     // 还没到目的地,那就取一次汽油,取经过的汽油中最多的 startFuel = cache.top(); cache.pop();++res;}}if(cur >= target) return res;return -1;}
};

http://www.lryc.cn/news/454821.html

相关文章:

  • OpenCV-OCR
  • Linux卸载mysql
  • 【大语言模型-论文精读】用于医疗领域摘要任务的大型语言模型评估综述
  • 图吧工具箱
  • vue2 + View design 使用inputNumber设置默认值为undefined但展示数据为1且表单校验不通过的原因
  • 【SpringSecurity】基本流程
  • 算法-汉诺塔问题(Hanoi tower)
  • HarmonyOS鸿蒙 Next 实现协调布局效果
  • 【自然语言处理】(1) --语言转换方法
  • 叉车防撞系统方案,引领安全作业新时代
  • Nginx的核心架构和设计原理
  • leetcode35--搜索插入位置--二分查找刷题
  • Django对接支付宝沙箱环境(2024年9月新测有效)
  • 【MySQL】-- 库的操作
  • linux桌面软件(wps)内嵌到主窗口后的关闭问题
  • WindowsTerminal 美化-壁纸随机更换
  • iOS 多次获取图片主题色不一样
  • UE5 武器IK瞄准系统
  • ①EtherCAT转ModbusTCP, EtherCAT/Ethernet/IP/Profinet/ModbusTCP协议互转工业串口网关
  • 在macOS上进行开发环境配置与应用开发详细的配置指南
  • JavaScript 事件处理基础
  • WordPress响应式Git主题响应式CMS主题模板
  • Solidity 设计模式:实现灵活与可扩展的智能合约架构
  • 房屋水电费:重新布局,重构JS代码
  • Jmeter生成JWT token
  • STM32的ADC技术详解
  • PySpark把一列数据上下移动,时序数据
  • 网络基础 【HTTPS】
  • 51单片机的红外感应洗手器【proteus仿真+程序+报告+原理图+演示视频】
  • 【11】纯血鸿蒙HarmonyOS NEXT星河版开发0基础学习笔记-模块化语法与自定义组件