面试经典150题——加油站

面试经典150题 day14

题目来源

力扣每日一题;题序:134

我的题解

方法一 找最低点

参考 labuladong

找到最低点的下一个站 经过i之后变成最低点,则从i+1站开始
时间复杂度 :O(n)
空间复杂度:O(1)

java 复制代码
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)

java 复制代码
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 分钟前
二叉树基础精讲(上):树形结构 · 二叉树概念 · 性质 · 遍历 · 基础操作全解析
java·数据结构·算法
chalmers_151 分钟前
Node.js 后端 + 简易运维岗---面试全套指南(1)
面试·职场和发展·node.js
biwenjun9992 分钟前
chatBI构建思路拆解(重点是元数据增强)
java·数据库·人工智能
Rsun045512 分钟前
8、Java 代理模式从入门到实战
java·系统安全·代理模式
Q741_1473 分钟前
每日一题 力扣 2515.到目标字符串的最短距离 循环数组 C++题解
c++·算法·leetcode
Dfreedom.6 分钟前
聚类算法对比分析:K-Means、DBSCAN 与层次聚类
人工智能·算法·机器学习·kmeans·聚类
cmpxr_7 分钟前
【C】结构体的内存对齐
c语言·开发语言·算法
人道领域8 分钟前
【黑马点评日记02】Redis解决Tomcat集群Session共享问题
java·前端·后端·架构·tomcat·firefox
cheems95278 分钟前
[JavaEE]深度解构 Spring 核心:从控制反转 (IoC) 到依赖注入 (DI) 的架构演进
java·spring·架构·java-ee
毅炼11 分钟前
MySQL常见问题总结(2)
java·数据库·mysql