题目描述
环形路上有n个加油站,第i个加油站的汽油量是gas[i].
你有一辆车,车的油箱可以无限装汽油。从加油站i走到下一个加油站(i+1)花费的油量是cost[i],你从一个加油站出发,刚开始的时候油箱里面没有汽油。
求从哪个加油站出发可以在环形路上走一圈。返回加油站的下标,如果没有答案的话返回-1。
注意:答案保证唯一。
输入
[2,3,1],[3,1,2]
输出
1
个人思路:新建一个环形链表,记录gas[i]与cost[i]的差值,从第一个非负插值处index开始循环,记录插值的总和,若循环一周每次sum+=gas[i]-cost[i]总和sum>=0,则index即为解,否则寻找下一个index。(未成功实现)
牛友思路:从start出发, 如果油量足够, 可以一直向后走 end++; 油量不够的时候,start向后退 最终 start == end的时候,如果有解一定是当前 start所在位置
public class Solution { /** * * @param gas int整型一维数组 * @param cost int整型一维数组 * @return int整型 */ public int canCompleteCircuit (int[] gas, int[] cost) { // write code here int start=gas.length-1; int end=0; int sum=gas[start]-cost[start]; while(start>end){ if(sum>=0){ sum+=gas[end]-cost[end]; end++; }else{ start--; sum+=gas[start]-cost[start]; } } if(sum>=0) return start; else return -1; } }