Leetcode 45-跳跃游戏 II

news2024/11/24 6:42:13

题解

法一 找当前可跳到最远的起始位置(贪心法)

局部最优: 当前覆盖范围内尽选可到达最远的一步,如果还没到终点,步数再加一。
整体最优: 一步尽可能多走,从而达到最少步数。

  • 本题和55题不同,55题只需在当前可覆盖范围内找到可覆盖的最远的位置,相当于可以不断跳跃,不断更新最大覆盖范围, 最后得到整体最大覆盖范围,看是否能到终点。
  • 本题为了尽可能减少跳跃步数,不能每次跳跃,本题只在找到当前可覆盖范围内可跳跃最远的一个位置i作为下一步的起点开始跳跃,并更新下一步可覆盖的范围。这里需要统计两个覆盖范围,当前这一步的最大覆盖和下一步最大覆盖。
  • 如果到达当前这一步的最大覆盖最远距离(curCover)还没有到终点的话,那么就必须再走一步(step++,curCover=nextCover)来增加覆盖范围。如何更新下一步可覆盖的范围?遍历i到curCover,通过选择最大的(i+nums[i])不断更新nextCover和curCover。
    图片转载自代码随想录
    在这里插入图片描述
//贪心解法:跳的步数尽可能少-->每一步跳的距离尽可能远
//局部贪心:在当前能覆盖的区域里选择下一步的起始位置,下一步覆盖的距离要尽可能远
//step什么时候更新?到达当前这一步覆盖的边界的时候+1
class Solution {
    public int jump(int[] nums) {
        //走0步时覆盖范围为0
        int curCover=0;
        int nextCover=nums[0];
        int step=0;
        for(int i=0;i<nums.length;i++){
            if(curCover>=nums.length-1) break;
            //更新下一步可覆盖的区域边界
            nextCover=Math.max(nextCover,i+nums[i]);
            //到达当前这一步覆盖的边界的时候,step必须+1,curCover=nextCover
            if(i==curCover){
                step++;
                curCover=nextCover;
            }
        }
        return step;
    }
}

法二 找可到达终点的最靠前的位置(贪心法)

知道最终要到达最后一个位置,然后我们找前一个位置,遍历数组,找到能到达它的位置,离它最远的就是要找的位置。然后继续找上上个位置,最后到了第 0 个位置就结束了。

至于离它最远的位置,其实我们从左到右遍历数组,第一个满足的位置就是我们要找的
图片转载自windliang
在这里插入图片描述

//从后往前找可以到达nums.length-1位置的最靠前的数
//怎么找最靠前的数?从前往后遍历到的第一个能到达nums.length-1的数即为最靠前的数
//找到了以后更新需要到达的数(position=nums.length-1-->position=找到的位置i),且step++,循环往复
//贪心法里面经常用到的一个手法,更新待循环的数组范围
class Solution {
    public int jump(int[] nums) {
        int position=nums.length-1;
        int step=0;
        while(position>0){
            for(int i=0;i<position;i++){
                if(nums[i]+i>=position){
                        step++;
                        //将当前的i置为下次跳转需要到达的点
                        position=i;
                        //这一步使得此轮循环结束,下一轮的遍历起点还是0,遍历目标是找到i使得nums[i]+i>position
                 }
                if(position==0) break;
            }
        }
       
        return step;
    }
}

法三 暴力搜索(动态规划)

dp[i]:能跳到该数组需要的最小步数
通过dp[i+count]=Math.min(dp[i]+1,dp[i+count])更新到达dp[i+count]的最小步数

//dp[i]:能跳到该数组需要的最小步数
//dp[i+count]=Math.min(dp[i]+1,dp[i+count]) count<=nums[i]
class Solution {
    public int jump(int[] nums) {
        int[] dp=new int[nums.length];
        for(int i=0;i<nums.length;i++){
            dp[i]=Integer.MAX_VALUE;
        }
        //初始化
        dp[0]=0;
        for(int i=0;i<nums.length;i++){
            int count=nums[i];
            while(count>0&&dp[i]!=Integer.MAX_VALUE){
                if(dp[nums.length-1]!=Integer.MAX_VALUE) return dp[nums.length-1];
                if(i+count<nums.length) dp[i+count]=Math.min(dp[i]+1,dp[i+count]);
                count--;
            }
        }
        return dp[nums.length-1];
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2164394.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

通义灵码最佳使用实践:如何深度使用辅助功能

通义灵码是JetBrains或VSCode集成开发环境&#xff08;IDE&#xff09;中嵌入的一款智能开发助手工具&#xff0c;旨在通过人工智能技术简化软件开发过程&#xff0c;提升开发效率。本文将介绍在开发过程中如何深度体验多种辅助功能。其主要功能包括&#xff1a;通用大模型问答…

win11任务栏怎么自定义调整?任务栏透明设置技巧分享(实用功能)

Win11任务栏是可以自定义设置的&#xff0c;那么怎么把任务栏变透明呢&#xff1f;最近很多小伙伴都在咨询Windows11任务栏怎么透明&#xff1f;那还不简单吗&#xff0c;本文整理了一些关于Windows任务栏自定义调整的教程&#xff0c;包括win11任务栏透明、隐藏任务栏、显示任…

阿里发布视频大模型,快来体验

传送门&#xff1a;https://tongyi.aliyun.com/wanxiang/videoCreation 使用说明&#xff1a;https://alidocs.dingtalk.com/i/nodes/jb9Y4gmKWrx9eo4dCql9LlbYJGXn6lpz?spm5176.29623064.0.0.41ed1eceDjrPw0&utm_sceneperson_space

大数据新视界 --大数据大厂之大数据实战指南:Apache Flume 数据采集的配置与优化秘籍

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

如何使用ssm实现基于SpringMVC网上选课系统的设计与实现

TOC ssm696基于SpringMVC网上选课系统的设计与实现jsp 研究背景和来源 目前的管理类系统已各种各样&#xff0c;涉及到生活中的每一个部分。购物类、网站类、信息统计类、办公类、官网类等非常丰富。我国各类系统的发展已非常成熟&#xff0c;这些系统依靠网络和计算机技术不…

多网站域名共享微信网页授权:PHP实现微信授权代理转发

在做网站需要微信扫码或微信内授权注册登陆&#xff0c;但是做过类似功能的都知道&#xff0c;需要授权登陆比较麻烦。 需要满足以下条件&#xff1a; 申请公众号网站域名备案开放平台注册新建应用审核 有没有简单&#xff0c;不需要申请免备案可用的方案&#xff0c;答案肯…

解决 ValueError: did not find HDF5 headers----安装netCDF4报错

报错如图 报错说是hdf5找不到&#xff0c;按照这个思路搞了半天都没搞好。后来换了一个安装命令 pip install netcdf41.5.7 成功&#xff01;&#xff01;

基于vue框架的大连盐业有限公司生产管理系统的设计与实现3hk5y(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。

系统程序文件列表 项目功能&#xff1a;计划员,工艺员,生产建模,生产计划,生产信息,生产监视,工艺质量,盐政信息 开题报告内容 一、引言 随着信息技术的飞速发展和市场竞争的日益激烈&#xff0c;传统盐业企业如大连盐业有限公司正面临着转型升级的迫切需求。传统管理模式下…

python-比较月亮大小/数组下标/人见人爱a+b

一:比较月亮大小 题目描述 小理是一名出色的狼人。众所周知&#xff0c;狼人只有在满月之夜才会变成狼。 同时&#xff0c;月亮的大小随着时间变化&#xff0c;它的大小变化 3030 天为一循环。 它的变化情况(从第一天开始)为 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,14,13,12,1…

Python提供内置正则表达式库

正则表达式是一种强大的文本处理工具&#xff0c;可以匹配文本片段的模式 最简单的正则表达式就是普通的字符串&#xff0c;可以匹配自身 要注意的是&#xff0c;正则表达式并不是一个程序&#xff0c;它使用一种特定的语法模式来描述在搜索文本时要匹配的一个或多个字符串。正…

UE5 C++: 插件编写05 | 批量删除无用资产

删除无用的asset 已经在地图中使用的asset会有asset reference EditorAssetLibrary&#xff08;按F12&#xff09;open header file&#xff0c;会有如下一个功能&#xff0c;可以找asset reference&#xff0c;返回bool值 UFUNCTION(BlueprintCallable, Category "Edi…

wpf在图上画矩形,矩形可拖动、大小可调节,使用装饰器Adorner调整矩形大小,限制拖动和调节范围

效果 功能 使用wpf实现 在图片上画一个矩形框该矩形框可以调节大小该矩形框可以拖动调整位置 注&#xff1a;这里的鼠标事件是&#xff0c;双击在图上画一个固定大小的矩形框&#xff0c;右键按住拖动矩形框。有需要的可以自行调整对应的鼠标事件 参考资料&#xff1a;https…

心理测试小程序开发心理健康MBTI人格测试,小程序源码部署支持多种流量主

简介 在当今这个高速运转的社会里&#xff0c;个人内心性格与心理健康日益成为人们关注的焦点。随着科技的日新月异&#xff0c;心理评估的方式正经历着深刻的变革&#xff0c;从传统的面对面咨询室中解放出来&#xff0c;无缝融入了我们日常使用的移动设备之中。这一趋势极大…

【网络安全】网络基础第一阶段——第四节:网络协议基础---- VRRP与网络架构设计

目录 一、VRRP 1.1 VRRP使用场景及简介 1.2 VRRP基本原理 1.2.1 VRRP基本结构 1.2.2 设备类型 1.2.3 VRRP工作原理 1.3 VRRP的基本配置 1.3.1 基于三层交换机的VRRP组配置 1.3.2 SMTPVRRP经典组网 1.4 端口聚合 1.4.1 端口聚合技术 1.4.2 聚合模式 1.4.3 Eth-trun…

Python项目Flask框架整合Redis

一、在配置文件中创建Redis连接信息 二、 实现Redis配置类 import redis from config.config import REDIS_HOST, REDIS_PORT, REDIS_PASSWD, REDIS_DB, EXPIRE_TIMEclass RedisDb():def __init__(self, REDIS_HOST, REDIS_PORT, REDIS_DB, EXPIRE_TIME, REDIS_PASSWD):# 建立…

【笔记】KaiOS 系统框架和应用结构(APP界面逻辑)

KaiOS系统框架 最早自下而上分成Gonk-Gecko-Gaia层,代码有同名的目录,现在已经不用这种称呼。 按照官网3.0的版本迭代介绍,2.5->3.0已经将系统更新成如下部分: 仅分为上层web应用和底层平台核心,通过WebAPIs连接上下层,这也是kaios系统升级变更较大的部分。 KaiOS P…

Spring Boot 点餐系统:您的餐饮技术伙伴

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于网上点餐系统当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了网上点餐系统&#xff0c;它彻底改变了过去传统的…

Spring不能处理的循环依赖

文章目录 场景一&#xff1a;prototype 类型的循环依赖场景二&#xff1a; constructor 注入的循环依赖场景三&#xff1a;普通的 AOP 代理 Bean 的循环依赖–默认是可以的场景四&#xff1a;Async 增强的 Bean 的循环依赖总结 参考&#xff1a;https://blog.csdn.net/wang4896…

Redis系列补充:聊聊布隆过滤器(go语言实践篇)

1 介绍 布隆过滤器&#xff08;Bloom Filter&#xff09;是 Redis 4.0 版本之后提供的新功能&#xff0c;我们一般将它当做插件加载到 Redis Service服务器中&#xff0c;给 Redis 提供强大的滤重功能。 它是一种概率性数据结构&#xff0c;可用于判断一个元素是否存在于一个集…

Elasticsearch导出导入数据

1.概念回顾 2.基础操作 展示详细信息 GET&#xff1a;http://127.0.0.1:9200/_cat/indices?v Java代码将文件导入到ES package com.Graph.medicalgraph;import org.apache.http.HttpHost; import org.elasticsearch.action.bulk.BulkRequest; import org.elasticsearch.act…