leetcode_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 check = 0;
int sy=0;
int ans=-1;
for(int i=0;i<gas.length;i++){
int j=i;//从i出发
sy=0;
for(int k=0;k<gas.length;k++){//总共走5步
sy=sy+gas[j]-cost[j];
if(sy<0){
break;
}else{
if(i==next(gas,j)){
check=1;
break;
}else{
j=next(gas,j);
}
}
}
if(check==1){
ans=i;
break;
}
}
return ans;
}
//求出下一个加油站的下标
public int next(int[] gas,int i){
if(i==gas.length-1){
return 0;
}else{
return i+1;
}
}