leetcode: gas-station

题目描述:

沿着环形路线 有N个加油站,其中站i的气体量是气体 [i]。

你有一辆带有无限油箱的汽车,从车站i到下一站(i + 1)需要花费 {i} 气。您可以在其中一个加油站开始使用空罐。

如果您可以在电路周围行驶一次,则返回起始加油站的索引,否则返回-1。

注意:
解决方案保证是唯一的。

解题思路:

  1. 这道题很好理解,我觉得它考察的点就是贪心算法
  2. 注意这道题有一个隐藏的关键点就是:解决方案保证是唯一的
  3. 就是说 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;
    }

转载于:https://my.oschina.net/happywe/blog/3085924

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值