134. 加油站
在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升。
你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发,开始时油箱为空。
如果你可以绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/gas-station
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public int canCompleteCircuit(int[] gas, int[] cost) {
int ret = 0, curGas = 0, sum = 0;
for (int i = 0; i < gas.length; ++i) {
sum += gas[i] - cost[i];
curGas += gas[i] - cost[i];
if (curGas < 0) {
ret = i + 1;
curGas = 0;
}
}
return sum >= 0 ? ret : -1;
}
}
心之所向,素履以往 生如逆旅,一苇以航

浙公网安备 33010602011771号