当前位置: 首页 > news >正文

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

题目:在一条环路上有n个加油站,其中第i个加油站有汽油 gas[i]升.。
           你有一辆油箱容量无限的的汽车,从第i个加油站开往第i+1个加油站需要消耗汽油 cost[i]升。你从其中的一个加油站出发,开始时油箱为空。
           给定两个整数数组 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.从起点开始,模拟一遍加油的流程即可

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):

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));
        }
    }

相关文章:

  • Flask接口开发--引入mysql
  • 刷机维修进阶教程-----adb禁用错了系统app导致无法开机 如何保数据无损恢复机型
  • 2025年- G27-Lc101-542. 01 矩阵--java版
  • SQL GROUP BY 自定义排序规则
  • Linux:一些命令记录
  • vue3+vite+js快速搭建前端项目
  • OpenCV正确安装及环境变量配置
  • Langchain 自定义工具和内置工具
  • 关于脏读,不可重复读和幻读
  • LeetCode热题100JS(69/100)第十三天|34|33|153|4|20
  • 论文写作篇#7:YOLO论文中的全称和缩写,什么时候全称什么时候缩写,全称和缩写谁在括号里?
  • 约束文件SDC常用命令
  • 【Go】数组
  • 中间件监控:保障应用稳定性和响应速度
  • Servlet中request、response、session 用法
  • C++学习笔记(二十五)——vector
  • OpenCV第2课 OpenCV的组成结构与图片/视频的加载及展示
  • MapReduce1中资源预先划分为固定数量的map slot和reduce slot,具体是怎么划分的?
  • 深度强化学习(Deep Reinforcement Learning, DRL)
  • java 批量下载doc\excle\pdf
  • 新希望一季度归母净利润4.45亿,上年同期为-19.34亿
  • 新开发银行如何开启第二个“金色十年”?
  • 中信银行一季度净利195.09亿增1.66%,不良率持平
  • 力箭二号火箭成功进行满载起竖试验,计划今年首飞发射轻舟飞船
  • 逛了6个小时的上海车展。有些不太成熟的感受。与你分享。
  • 众信旅游:去年盈利1.06亿元,同比增长228.18%