leetcode134:加油站

加油站

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

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

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

java 复制代码
public int canCompleteCircuit(int[] gas, int[] cost) {
        int store = 0;
        int MIN = Integer.MAX_VALUE;
        int index = -1;
        for (int i = 0; i < gas.length; i++) {
            store = store - cost[i] +gas[i] ;
            if(store < MIN){
                MIN = store;
                index = i;
            }
        }
        return store>=0 ? (index + 1)%gas.length : -1;
    }

贪心,因为是唯一解,找到跑一圈中总和最小的时刻,从这个时刻后面开始跑即可

相关推荐
啊阿狸不会拉杆1 分钟前
《数字图像处理》实验3-频率域处理方法
图像处理·人工智能·算法·计算机视觉·数字图像处理
海南java第二人6 分钟前
深入剖析AQS:Java并发编程的核心基石与底层实现原理
java
代码游侠6 分钟前
应用——HTTP天气查询
网络·笔记·网络协议·算法·http
趁月色小酌***6 分钟前
JAVA 知识点总结3
java·开发语言·python
永远睡不够的入8 分钟前
记数排序(基数排序和桶排序)
数据结构
智航GIS11 分钟前
6.1 for循环
开发语言·python·算法
fufu031111 分钟前
Linux环境下的C语言编程(五十二)
java·linux·c语言
爱学大树锯14 分钟前
353 · 最大字母」
算法
YGGP15 分钟前
【Golang】LeetCode 416. 分割等和子集
算法·leetcode
BD_Marathon19 分钟前
Spring是什么
java·后端·spring