码农知识堂 - 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。

  • 相关阅读:
    【树莓派不吃灰】搭建Node-Red可拖拽图形化物联网
    太空射击第09课:精灵动画
    Windows11更新后Chrome无法打开解决方案
    程序员的数学课02 逻辑与沟通,怎样才能讲出有逻辑的话?
    还在用命令行看日志?快用Kibana吧,可视化日志分析YYDS
    【VUE异常】el-popconfirm失效,@confirm事件不生效,点击没有任何反应,刷新页面才能点击
    大数据必学Java基础(八十八):通过案例和概念体会反射的好处
    七分钟学会 HTML 网页制作
    利用CMOS数字隔离器提高智能计量解决方案的数据完整性和可靠性
    【Python+C#】手把手搭建基于Hugging Face模型的离线翻译系统,并通过C#代码进行访问
  • 原文地址: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号