面试经典150题——加油站

题目来源

力扣每日一题;题序:134

我的题解

方法一 找最低点

参考 labuladong
找到最低点的下一个站 经过i之后变成最低点,则从i+1站开始

时间复杂度:O(n)
空间复杂度:O(1)

class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int n=gas.length;
        int sum=0;
        int start=0;
        int minSum=0;
        for(int i=0;i<n;i++){
            sum+=gas[i]-cost[i];
            if(sum<minSum){
            // 经过第 i 个站点后,使 sum 到达新低
            // 所以站点 i + 1 就是最低点(起点)
                start=i+1;
                minSum=sum;
            }
        }
        if(sum<0){
        // 总油量小于总的消耗,无解
            return -1;
        }
        return start==n?0:start;
    }
}
方法二 贪心

时间复杂度:O(n)
空间复杂度:O(1)

class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int n=gas.length;
        int sum=0;
        int start=0;
        int myGas=0;
        for(int i=0;i<n;i++){
            sum+=gas[i]-cost[i];
            myGas+=gas[i]-cost[i];
            // 如果选择站点 start 作为起点「恰好」无法走到站点 i,那么 start 和 i 中间的任意站点 k 都不可能作为起点。只能从i+1开始重新寻找可以作为起点的位置
            if(myGas<0){
                start=i+1;
                myGas=0;
            }
        }
        if(sum<0){
            return -1;
        }
        return start==n?0:start;
    }
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐

  1. 面试经典150——加油站

    2024-04-23 10:38:03       36 阅读
  2. LeetCode 面试经典150 134.加油站

    2024-04-23 10:38:03       37 阅读
  3. 【leetcode面试经典150】14.加油站(C++)

    2024-04-23 10:38:03       36 阅读
  4. 面试经典 150

    2024-04-23 10:38:03       26 阅读
  5. 面试经典150(96-100)

    2024-04-23 10:38:03       63 阅读
  6. 面试经典150(108-110)

    2024-04-23 10:38:03       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-23 10:38:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-23 10:38:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-23 10:38:03       82 阅读
  4. Python语言-面向对象

    2024-04-23 10:38:03       91 阅读

热门阅读

  1. RabbitMQ:消息队列的卓越之选

    2024-04-23 10:38:03       34 阅读
  2. kubernetes中的静态POD

    2024-04-23 10:38:03       43 阅读
  3. kitti2bag,py 报错

    2024-04-23 10:38:03       59 阅读
  4. P8739 [蓝桥杯 2020 国 C] 重复字符串

    2024-04-23 10:38:03       32 阅读
  5. hive通过正则过滤其他字段

    2024-04-23 10:38:03       39 阅读
  6. 数学分析复习:洛必达法则、泰勒公式

    2024-04-23 10:38:03       40 阅读
  7. AntD上传文件 结合Axios 服务端由Spring MVC接收

    2024-04-23 10:38:03       31 阅读
  8. Hive第二篇HQL

    2024-04-23 10:38:03       37 阅读
  9. Hive第一篇简介

    2024-04-23 10:38:03       30 阅读
  10. 7、docker 集群

    2024-04-23 10:38:03       36 阅读
  11. 数仓建模—维度建模之维度表

    2024-04-23 10:38:03       39 阅读