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

leetcode-134. 加油站-贪心策略

在一条环路上有 n 个加油站,其中第 i 个加油站有汽油 gas[i] 升。

你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发,开始时油箱为空。

给定两个整数数组 gas 和 cost ,如果你可以按顺序绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1 。如果存在解,则 保证 它是 唯一 的。

示例 1:

输入: gas = [1,2,3,4,5], cost = [3,4,5,1,2]
输出: 3
解释:
从 3 号加油站(索引为 3 处)出发,可获得 4 升汽油。此时油箱有 = 0 + 4 = 4 升汽油
开往 4 号加油站,此时油箱有 4 - 1 + 5 = 8 升汽油
开往 0 号加油站,此时油箱有 8 - 2 + 1 = 7 升汽油
开往 1 号加油站,此时油箱有 7 - 3 + 2 = 6 升汽油
开往 2 号加油站,此时油箱有 6 - 4 + 3 = 5 升汽油
开往 3 号加油站,你需要消耗 5 升汽油,正好足够你返回到 3 号加油站。
因此,3 可为起始索引。

示例 2:

输入: gas = [2,3,4], cost = [3,4,3]
输出: -1
解释:
你不能从 0 号或 1 号加油站出发,因为没有足够的汽油可以让你行驶到下一个加油站。
我们从 2 号加油站出发,可以获得 4 升汽油。 此时油箱有 = 0 + 4 = 4 升汽油
开往 0 号加油站,此时油箱有 4 - 3 + 2 = 3 升汽油
开往 1 号加油站,此时油箱有 3 - 3 + 3 = 3 升汽油
你无法返回 2 号加油站,因为返程需要消耗 4 升汽油,但是你的油箱只有 3 升汽油。
因此,无论怎样,你都不可能绕环路行驶一周。

提示:

  • gas.length == n
  • cost.length == n
  • 1 <= n <= 105
  • 0 <= gas[i], cost[i] <= 104
// 解决方案类
class Solution {
public:
    /**
     * 判断是否可以环绕一圈
     * @param gas 加油站的汽油量数组
     * @param cost 汽车从每个加油站行驶到下一个加油站的耗油量数组
     * @return 如果可以环绕一圈,返回起始加油站的索引;否则返回-1
     */
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
        int nums = 0; // 汽车油箱
        int len = gas.size(); // 加油站数量

        // 使用前n项和的思想来计算
        int startid = 0; // 记录可能的起始加油站索引
        int gasnums = 0; // 累计汽油量
        int costnums = 0; // 累计耗油量

        // 遍历加油站,计算前n项和
        for (int i = 0; i < len; i++) {
           gasnums += gas[i];
           costnums += cost[i];
           // 如果当前累计汽油量不足以到达下一个加油站,更新起始加油站
           if (gasnums - costnums < 0) {
               startid = i + 1;
               gasnums = 0;
               costnums = 0;
           }
        }

        // 再次检查从startid到len-1的累计汽油量是否足以环绕一圈
        for (int i = 0; i < startid; i++) {
            gasnums += gas[i];
            costnums += cost[i];
            // 如果累计汽油量不足以环绕一圈,返回-1
            if (gasnums - costnums < 0) {
                return -1;
            }
        }

        // 如果可以环绕一圈,返回起始加油站的索引
        return startid;
    }
};

 


http://www.kler.cn/news/327504.html

相关文章:

  • 数据结构与算法学习(2)
  • 汽车灯光系统详细介绍
  • 【机器学习】---深入探讨图神经网络(GNN)
  • 【STM32】 TCP/IP通信协议(3)--LwIP网络接口
  • 将 Intersection Observer 与自定义 React Hook 结合使用
  • 基于RPA+BERT的文档辅助“悦读”系统 | OPENAIGC开发者大赛高校组AI创作力奖
  • ruoyi-python 若依python版本部署及新增模块
  • 基于springboot+微信小程序社区超市管理系统(超市3)(源码+sql脚本+视频导入教程+文档)
  • 使用 CMake 构建 C 语言项目
  • 《Zeotero的学习》
  • Linux中安装ffmpeg
  • 随手记:牛回速归
  • Simulink仿真中get_param函数用法
  • 代码随想录算法训练营Day14
  • 【C#】CacheManager:高效的 .NET 缓存管理库
  • PCL库简单NDT算法配准
  • mini-lsm通关笔记Week2Overview
  • SpringBoot中使用XXL-JOB实现灵活控制的分片处理方案
  • C++的类型转换
  • Redis: 主从复制读写分离环境搭建
  • 2024电脑视频剪辑软件全解析与推荐
  • Prompt:在AI时代,提问比答案更有价值
  • O2OA(翱途)服务器故障排查
  • 学习经验分享【38】YOLOv11解读——最新YOLO版本
  • linux文件编程_文件
  • 记录一次gRpc流式操作
  • 正则表达式的使用示例--Everything文件检索批量重命名工具
  • 使用 Python 实现图形学的辐射度算法
  • Flask-2
  • Gpt4.0最新保姆级教程开通升级