面试经典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;
    }
}

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

相关推荐
RainbowSea14 分钟前
伙伴匹配系统(移动端 H5 网站(APP 风格)基于Spring Boot 后端 + Vue3 - 06
java·spring boot·后端
金融小师妹21 分钟前
AI多因子模型解析:黄金涨势受阻与美联储9月降息政策预期重构
大数据·人工智能·算法
顾林海37 分钟前
从"面条代码"到"精装别墅":Android MVPS架构的逆袭之路
android·面试·架构
FogLetter41 分钟前
面试官问我Function Call,我这样回答拿到了Offer!
前端·面试·openai
CHENFU_JAVA43 分钟前
EasyExcel 合并单元格最佳实践:基于注解的自动合并与样式控制
java·excel
AAA修煤气灶刘哥1 小时前
日志排查不用慌!从采集到 ELK 实战,手把手教你搞定线上问题
后端·面试·debug
似水流年流不尽思念1 小时前
MySQL 的 MVCC 到底解决了幻读问题没有?请举例说明。
mysql·面试
就是帅我不改1 小时前
SpringBoot多租户架构设计终极指南:5种方案彻底解决企业级SaaS隔离难题
后端·面试·架构
NAGNIP1 小时前
LLaMA 3:离 AGI 更近一步?
算法
页面仔Dony1 小时前
任务队列的中断和恢复实现
javascript·面试