LeetCode 面试经典150题 134.加油站

题目

在一条环路上有 n 个加油站,其中第 i 个加油站有汽油 gas[i]升。

你有一辆油箱容量无限的的汽车,从第i个加油站开往第i+1个加油站需要消耗汽油 cost[i]升。你从其中的一个加油站出发,开始时油箱为空。

给定两个整数数组 gascost ,如果你可以按顺序绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1 。如果存在解,则 保证 它是 唯一 的。

思路:从x出发,到y走不下去了。那么对于x到y中的所有节点z,如果从z出发,一定会在y处卡住。应用这个结论,我们在遍历的时候,不需要遍历x到y中的节点了,只需要从走不下去的节点y的下一个节点作为起始遍历即可。

代码

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int n = gas.length;
        // 起点i
        int i = 0;
        while (i < n) {
            int sumOfGas = 0, sumOfCost = 0;
            // 记录经过的车站数
            int count = 0;
            while (count < n) {
                int j = (i + count) % n;
                sumOfGas += gas[j];
                sumOfCost += cost[j];
                // 走不下去
                if (sumOfCost > sumOfGas) {
                    break;
                }
                count++;
            }
            if (count == n) 
                return i;
            else 
                i = i + count + 1;
        }
        return -1;
    }
}

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

相关推荐
小欣加油17 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly17 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
不懂数据的小白17 小时前
面试题一:【二】异动分析(诊断)
面试
Aphasia31118 小时前
https连接传输流程
前端·面试
徐小夕18 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei19 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
kyriewen19 小时前
CSS Container Queries:彻底告别 @media 写到手软,附 5 个真实布局案例
前端·css·面试
Hello:CodeWorld19 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi820 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
mONESY21 小时前
JavaScript 栈、队列、数组与链表核心知识点总结
javascript·面试