题目描述:
沿着环形路线 有N个加油站,其中站i的气体量是气体 [i]。
你有一辆带有无限油箱的汽车,从车站i到下一站(i + 1)需要花费 {i} 气。您可以在其中一个加油站开始使用空罐。
如果您可以在电路周围行驶一次,则返回起始加油站的索引,否则返回-1。
注意:
解决方案保证是唯一的。
解题思路:
这道题很好理解,我觉得它考察的点就是贪心算法
注意这道题有一个隐藏的关键点就是:解决方案保证是唯一的
就是说 gas[i] - cost[i] > 0 的情况只会出现一次
代码如下:
public int canCompleteCircuit(int[] gas, int[] cost) {
int sum = 0;
int total = 0;
int index = 0;
// sum 用来记录当前的剩余,如果大于 0,继续遍历,小于 0 重新选择 index
// total 用来记录是否会出现不存在解的情况
for(int i = 0; i < gas.length; i++){
sum += gas[i]-cost[i];
total += gas[i]-cost[i];
// 如果当前的节点使 sum 小于 0 ,那么它肯定不是初始节点,之前的也作废
if(sum < 0){
index=i+1;
sum = 0;
}
}
if(total<0)
return -1;
else
return index;
}