力扣 跳跃游戏 II

news/2025/2/22 2:49:07

贪心算法,存下每一步的最远,去达到全局的最小跳跃次数。

题目

从题中要达到最少次数,肯定是每一步尽可能走远一点。但注意j被限制了范围,这种不用想每一步遍历时肯定选最大的num[i],但要注意,题中是可以到达不是刚好到达,因此最后一步只要大于最后一个数都是可以的。从第一个数开始遍历,每一步贪心去选最远的距离,然后每个数都存下一个可达到的最远距离便于更新,因为贪心每一次都是基于当前数的最优,并不是全局最优。

时间复杂度: O(n),空间复杂度: O(1)。

java">class Solution {
    public int jump(int[] nums) {
        int step=0,end=0,furthest=0;
        for(int i=0; i<nums.length-1;i++){  
            furthest = Math.max(furthest, i+nums[i]);  //dp每个i,记录每个位置能达到的最远距离
            if(i==end){  //i遍历到上个起跳点能到的最远距离
                end = furthest;  //更新到下一步要跳到的位置,注意这里跳的最远距离由i前面的数贪心选出来的
                step++;  //来到这里就加了一步
            }
        }
        return step;
        
    }
}

动态规划是存一个要维护状态的dp数组,每次的状态由上几个状态更新得到,这题用dp会很慢。而贪心策略在于,每一步都存下最优状态便于后续的更新。

 


http://www.niftyadmin.cn/n/5857517.html

相关文章

【分布式理论13】分布式存储:数据存储难题与解决之道

文章目录 一、数据存储面临的问题二、RAID磁盘阵列的解决方案1. RAID概述2. RAID使用的技术3. RAID的代表性等级 三、分布式存储的新思路1. 分布式存储背景与特点2. 分布式存储的组成要素 一、数据存储面临的问题 在单机系统时代&#xff0c;当数据量不断增加、硬盘空间不够时…

BERT 大模型

BERT 大模型 EmbeddingTransformer预微调模块预训练任务 BERT 特点 : 优点 : 在语言理解相关任务中表现很好缺点 : 更适合 NLU 任务&#xff0c;不适合 NLG 任务 BERT 架构&#xff1a;双向编码模型 : Embedding 模块Transformer 模块预微调模块 Embedding Embedding 组成 …

异常处理、事务管理

异常处理 程序开发过程中不可避免的会遇到异常现象 如何处理 方案一&#xff1a;在Controller的方法中进行try...catch处理&#xff08;代码臃肿&#xff0c;不推荐&#xff09; 方案二&#xff1a;全局异常处理器 全局异常处理器 RestControllerAdvice &#xff1a;定义全…

GitLab 概念

GitLab 是一个基于 Git 的 DevOps 平台&#xff0c;提供了版本控制、持续集成/持续交付&#xff08;CI/CD&#xff09;、代码审查、项目管理等一系列功能。它帮助开发团队在整个软件生命周期中进行协作和管理。 具体来说&#xff0c;GitLab 提供以下功能&#xff1a; 版本控制…

pyqt写一个待办程序

ToDoApp 框架选择 一个简单的GUI程序&#xff0c;可以使用pyqt完成。pyqt是qt的python实现版本。 界面搭建 设计一个美观 简洁的界面 class ToDoApp(QWidget):def __init__(self):super().__init__()# 设置窗口属性self.setWindowTitle("Daily To Do List")self…

机器视觉--图像的运算(乘法)

一、引言 在图像处理领域&#xff0c;Halcon 是一款功能强大且广泛应用的机器视觉软件库。它提供了丰富的算子和工具&#xff0c;能够满足各种复杂的图像处理需求。图像的乘法运算作为其中一种基础操作&#xff0c;虽然不像一些边缘检测、形态学处理等操作那样被频繁提及&…

账号矩阵玩法:TikTok美区水晶手链如何实现规模化盈利?

打造TikTok美区水晶手链品牌的规模化盈利之路 在全球跨境电商迅速发展的今天&#xff0c;TikTok作为重要的营销平台&#xff0c;已经成为了无数品牌快速拓展市场的绝佳选择。然而&#xff0c;随着竞争的日益激烈&#xff0c;如何在这个平台上脱颖而出&#xff0c;取得规模化的…

使用 pjsua2 开发呼叫机器人,批量拨打号码并播放固定音频

如何使用 pjsua2 开发呼叫机器人&#xff0c;批量拨打号码并播放固定音频 声明 该播客仅提供实现思路&#xff0c;并非实际的方案记录&#xff0c;不要盲目照搬。 pjsua2库的安装会有较多问题&#xff0c;请参考本人之前的播客进行安装 pjsua2。 pjsua2 库具体的 api 说明请参…