贪心算法(11)(java)加油站

题目:在一条环路上有n个加油站,其中第i个加油站有汽油 gasi升.。

你有一辆油箱容量无限的的汽车,从第i个加油站开往第i+1个加油站需要消耗汽油 costi升。你从其中的一个加油站出发,开始时油箱为空。

给定两个整数数组 gas 和 cost,如果你可以按顺而环招行驶一周,则返回出发时加油站的编号,否则返回-1。如果存在解,则保证它是唯一的.

示例1:

输入:gas = 1,2,3,4,5,cost = 3,4,5,1,2

输出:3

解释:

从3号加油站(索引为3 处)出发,可获得4升汽油。此时油箱有 =0+4=4升汽油

开往 4号加油站,此时油箱有4-1+5=8升汽油

开往0号加油站,此时油箱有8-2+1=7升汽油

开往 1号加油站,此时油箱有7-3+2=6升汽油

开往 2 号加油站,此时油箱有6-4+3=5升汽油

开往 3号加油站,你需要消耗5升汽油,正好足够你返回到3号加油站。

因此 ,3可为起始索引。

解法1:暴力->枚举

1.依次枚举所有起点;

2.从起点开始,模拟一遍加油的流程即可

java 复制代码
public class Solution1 {
    public int canCompleteCircuit(int[]gas,int[] cost)
    {
        int n=gas.length;
        for(int i=0;i<n;i++)//依次枚举所有的起点
        {
            int rest=0;//统计净收益
            for(int step=0;step<n;step++)//枚举向后走的步数
            {
                int index=(i+step)%n;//走step不之后的下标
                rest=rest+gas[index]-cost[index];
                if(rest<0)
                {
                    break;
                }
            }
            if(rest>=0)
            {
                return i;
            }
        }
        return -1;
    }

    public static void main(String[] args) {
        Solution1 solution1=new Solution1();
        int []gas={1,2,3,4,5};
        int []cost={3,4,5,1,2};
        System.out.println(solution1.canCompleteCircuit(gas,cost));
    }
}

解法2:贪心:时间复杂度O(n):

java 复制代码
public class Solution2 {
        public int canCompleteCircuit(int[]gas,int[] cost)
        {
            int n=gas.length;
            for(int i=0;i<n;i++)//依次枚举所有的起点
            {
                int rest=0;//统计净收益
                int step=0;
                for(;step<n;step++)//枚举向后走的步数
                {
                    int index=(i+step)%n;//走step不之后的下标
                    rest=rest+gas[index]-cost[index];
                    if(rest<0)
                    {
                        break;
                    }
                }
                if(rest>=0)
                {
                    return i;
                }
                i=i+step;//贪心优化
            }
            return -1;
        }

        public static void main(String[] args) {
            Solution2 solution2=new Solution2();
            int []gas={1,2,3,4,5};
            int []cost={3,4,5,1,2};
            System.out.println(solution2.canCompleteCircuit(gas,cost));
        }
    }
相关推荐
kkeeper~19 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs66620 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641320 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚21 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本21 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov1 天前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫1 天前
特征工程处理
人工智能·算法·机器学习
z落落1 天前
C#参数区别
java·算法·c#
c238561 天前
vector(下)
数据结构·算法
z落落1 天前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法