码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 217.贪心算法:加油站(力扣)


    代码解决

    1. class Solution {
    2. public:
    3. int canCompleteCircuit(vector<int>& gas, vector<int>& cost)
    4. {
    5. int curtotol = 0; // 当前累积油量
    6. int tatol = 0; // 总的油量减去总的花费油量
    7. int start = 0; // 起始加油站的索引
    8. // 遍历所有加油站
    9. for (int i = 0; i < gas.size(); i++)
    10. {
    11. curtotol += gas[i] - cost[i]; // 计算当前累积油量
    12. tatol += gas[i] - cost[i]; // 计算总的油量减去总的花费油量
    13. // 如果当前累积油量小于0,则无法到达下一个加油站
    14. if (curtotol < 0)
    15. {
    16. start = i + 1; // 重置起点为下一个加油站
    17. curtotol = 0; // 重置当前累积油量
    18. }
    19. }
    20. // 如果总的油量小于总的花费油量,则无法完成环路
    21. if (tatol < 0) return -1;
    22. // 返回起始加油站的索引
    23. return start;
    24. }
    25. };

    核心思想

    1. 遍历每个加油站:
      • 计算从当前起点开始的累积油量。如果累积油量不足以到达下一个加油站,则从下一个加油站重新开始。
      • 如果总的油量 tatol 小于总的花费油量,说明无论从哪个加油站出发都无法绕环路一周,直接返回 -1。
      • 否则,返回最后一次重置起点的位置 start。

    假设 gas = [1, 2, 3, 4, 5] 和 cost = [3, 4, 5, 1, 2]:

    1. 遍历加油站:

      • i = 0: curtotol = 1 - 3 = -2, tatol = -2, start = 1, curtotol = 0
      • i = 1: curtotol = 2 - 4 = -2, tatol = -4, start = 2, curtotol = 0
      • i = 2: curtotol = 3 - 5 = -2, tatol = -6, start = 3, curtotol = 0
      • i = 3: curtotol = 4 - 1 = 3, tatol = -3
      • i = 4: curtotol = 5 - 2 = 6, tatol = 0
    2. 最终 tatol >= 0,返回 start = 3。

  • 相关阅读:
    【LeetCode】3. 无重复字符的最长子串
    微信小程序实现轮播图
    以太坊的最全概念攻略分享与案例分享|猿创征文
    DenseNet 浅析
    使用GitHub托管自己的静态资源
    【数据库与事务系列】多数据源切换
    C++ signed int 在计算机内部表示
    Navicat Premium连接Django项目的数据库
    java计算机毕业设计校园二手交易平台的设计源程序+mysql+系统+lw文档+远程调试
    活动安排问题--贪心算法
  • 原文地址:https://blog.csdn.net/weixin_63779802/article/details/140379088
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号