贪心算法---加油站

题目:

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

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

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

思路:

如果总油量减去总消耗大于等于0,那么一定可以跑完一圈,说明各个站点的加油站剩油量rest[i]之和是大于等于0的。

每个加油站的剩油量rest[i]为gas[i]-cost[i],i从0开始累加rest[i],和记为curSum,一旦curSum小于0,说明[0,i]区间都不能作为起始位置,因为这个区间选择任何一个位置作为起点,到这里都会断油,所以起点为i+1,curSum归0。

代码:

java 复制代码
    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)%gas.length;//如果不%,遍历到最后一个节点时index会溢出
                curSum=0;
            }
        }
        if(totalSum<0) return -1;
        return index;
    }
相关推荐
郝学胜-神的一滴4 分钟前
Python中的del语句与垃圾回收机制深度解析
服务器·开发语言·网络·python·算法
手握风云-6 分钟前
Java 数据结构第三十期:LRUCache 的“遗忘机制”
数据结构
重生之后端学习9 分钟前
17. 电话号码的字母组合
java·开发语言·数据结构·算法·深度优先
0 0 010 分钟前
CCF-CSP 32-2 因子化简(prime)【C++】考点:素数因子分解(试除法)
开发语言·数据结构·c++·算法
yyy(十一月限定版)11 分钟前
图论——最短路Dijkstra算法
算法·图论
重生之我是Java开发战士11 分钟前
【优选算法】分治:快速排序与归并排序
算法
专注VB编程开发20年15 分钟前
早期的redis是进程内的字典列表操作,后面改成TCP网络调用
数据库·redis·算法·缓存
仰泳的熊猫15 分钟前
题目1545:蓝桥杯算法提高VIP-现代诗如蚯蚓
数据结构·c++·算法·蓝桥杯
TracyCoder12315 分钟前
LeetCode Hot100(57/100)——5. 最长回文子串
算法·leetcode·职场和发展
载数而行52020 分钟前
复杂度问题
c语言·数据结构·c++·算法·排序算法