题目链接:牛客网
题目描述:
环形路上有n个加油站,第i个加油站的汽油量是gas[i].你有一辆车,车的油箱可以无限装汽油。从加油站i走到下一个加油站(i+1)花费的油量是cost[i],你从一个加油站出发,刚开始的时候油箱里面没有汽油。求从哪个加油站出发可以在环形路上走一圈。返回加油站的下标,如果没有答案的话返回-1。
注意:
答案保证唯一。
解题思路: 来自牛客网 牛客923
采用贪心的思路,假设起点start是最后一个加油站,假设终点end是第一个加油站,那么到达下一个加油站的油量就是sum=gas[start]-cost[start],当起点等于终点时遍历完所有的加油站。从最后一点开始走的时候,下一站是第一个加油站,如果sum=sum+gas[end]-cost[end]>=0,则说明可以走到下一个加油站,那么end++,继续往下一个加油站走,如果sum=sum+gas[end]-cost[end]<0,则说明不可以走到下一个加油站,那么就将start向前推1,sum=sum+gas[start]-cost[start],直到end=start。
如果最后的sum>=0则说明存在start,因为答案保证唯一,所以一定是最后的start,如果最后的sum<0则说明不存在start,则返回-1.
class Solution {
public:
int canCompleteCircuit(vector<int> &gas, vector<int> &cost) {
int start=gas.size()-1;//起始位置
int end=0;//结束位置
int sum=gas[start]-cost[start];//油量
while(start>end){//相等时说明走完整个环
if(sum>=0){//油量足够则end向前走1
sum=sum+gas[end]-cost[end];
end=end+1;
}else{//油量不够则start向后走1
start=start-1;
sum=sum+gas[start]-cost[start];
}
}//保证了每个点的sum值计算一次,最终的sum是遍历完所有点的sum
return sum>=0?start:-1;
}
};