加油站【贪心算法】

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

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

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

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int curSum = 0;
        int totalSum = 0;
        int index = 0;
        for (int i = 0; i < gas.length; i++) {
            //计算累加过程,积累下的汽油
            curSum += gas[i] - cost[i];
            totalSum += gas[i] - cost[i];
            //如果出现和为负数,说明不可行,清零当前剩余油量,并尝试从下个站点出发
            if (curSum < 0) {
                index = i + 1;
                curSum = 0;
            }
        }
        //遍历完之后,看totalSum是否大于等于0,由此判断能不能跑完一圈(需在for循环结束后(外面)判断)
        if (totalSum < 0) {
            return -1;
        }
        return index;
    }
}
相关推荐
imfbust29 分钟前
关于在矩阵中枚举点的 dp
算法
数懒女士36 分钟前
Java常见的锁策略
java·算法
8Qi81 小时前
多目标优化算法——多目标粒子群优化算法(MOPSO)
人工智能·算法·matlab·进化计算·群体智能
終不似少年遊*1 小时前
图论1基础内容
数据结构·python·学习·算法·图论
游是水里的游1 小时前
【算法day1】数组:双指针算法
数据结构·算法
2401_858286111 小时前
102.【C语言】数据结构之用堆对数组排序
c语言·开发语言·数据结构·算法·
阿芯爱编程1 小时前
数组拆分排序
java·后端·算法
是糖不是唐2 小时前
代码随想录算法训练营第五十九天|Day59 图论
c语言·算法·图论
赔罪2 小时前
最大公约数和最小公倍数-多语言
java·c语言·开发语言·javascript·python·算法
ydm_ymz2 小时前
实验07---7-11 一维数组的次大值
c语言·数据结构·算法