java gas station_leetcode: gas-station

题目描述:

沿着环形路线 有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;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值