2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版

1.题目描述

2.思路

每次尽可能往远一点跳,就能以最少的步数达到终点。

以最少的步数尽可能的增加覆盖范围,只要覆盖范围把最远的终点覆盖掉,就说明当前的步数可以跳到终点。

每次只记录下一步的最大范围。

3.代码实现

java 复制代码
public class H45 {
    public int jump(int[] nums) {

        if(nums.length==1)//如果只有1一个元素,说明不用跳(既是终点也是起点)
            return 0;
        int cur=0;//当前的覆盖范围的索引,从0开始
        int next=0;//下一步的覆盖范围
        int res=0;//记录当前的结果
        for(int i=0;i<nums.length;i++)
        {
            next=Math.max(i+nums[i],next);//两两比较,每次保存值最大的那个数,并赋值给next
            if(i==cur) {//当前一步的跳跃范围是否已经用完了
                //当前的位置不是数组的终点位置
                if (cur != nums.length - 1)
                {
                    res++;//还没到终点位置,结果(步数)+1
                    //把下一步的覆盖范围赋值给当前的复制范围
                    cur=next;
                    if(cur>nums.length-1)
                        break;
                }else {
                    break;
                }
            }
        }
        return res;


    }
    public static void main(String[] args)
    {
        H45 test=new H45();
        int[] nums={2,3,1,1,4};
        int ans=test.jump(nums);
        System.out.print(ans);
    }
}
相关推荐
小毅&Nora6 分钟前
【Java线程安全实战】⑨ CompletableFuture的高级用法:从基础到高阶,结合虚拟线程
java·线程安全·虚拟线程
码农小韩6 分钟前
基于Linux的C++学习——动态数组容器vector
linux·c语言·开发语言·数据结构·c++·单片机·学习
冰冰菜的扣jio6 分钟前
Redis缓存中三大问题——穿透、击穿、雪崩
java·redis·缓存
木风小助理7 分钟前
`mapfile`命令详解:Bash中高效的文本至数组转换工具
开发语言·chrome·bash
yyy(十一月限定版)16 分钟前
初始matlab
开发语言·matlab
LawrenceLan17 分钟前
Flutter 零基础入门(九):构造函数、命名构造函数与 this 关键字
开发语言·flutter·dart
listhi52017 分钟前
基于MATLAB的支持向量机(SVM)医学图像分割方法
开发语言·matlab
小璐猪头18 分钟前
专为 Spring Boot 设计的 Elasticsearch 日志收集 Starter
java
hui函数22 分钟前
如何解决 pip install 编译报错 g++: command not found(缺少 C++ 编译器)问题
开发语言·c++·pip
Tisfy31 分钟前
网站访问耗时优化 - 从数十秒到几百毫秒的“零成本”优化过程
服务器·开发语言·性能优化·php·网站·建站