LeetCode刷题之HOT100之跳跃游戏

2024/6/5 今天下起了绵密细雨,空气清新很多。昨晚做的梦较魔幻,可能也是导致我睡觉时业已破损的小米手环8的表腕断裂的因素之一。来到实验室,打扫一下卫生,听听歌,做道题。好不自在呀!

1、题目描述

在这里插入图片描述

2、逻辑分析

这道题与我们小时候玩的飞行棋有些相似,唯一不同的是这道题可以选择跳跃,最大长度不超过所在位置元素数值。又是动态规划问题吧,怎么解决呢?我还是不会做啊,总觉得差点哪一步就是做不出来。看了题解,发现跟我昨天做的最大子数组相似。

  1. 如果某一个作为 起跳点 的格子可以跳跃的距离是 3,那么表示后面 3 个格子都可以作为 起跳点
  2. 可以对每一个能作为 起跳点 的格子都尝试跳一次,把 能跳到最远的距离 不断更新
  3. 如果可以一直跳到最后,就成功了
    下面是具体代码实现

3、代码演示

public boolean canJump(int[] nums) {// k 用来记录当前能够到达的最远位置int k = 0;// 遍历数组中的每个元素for(int i = 0; i < nums.length; i++){// 如果当前位置i已经超出了当前能够到达的最远位置k,那么就无法到达这个位置,返回false if(i > k) return false;// 更新当前能够到达的最远位置k,取当前位置i加上当前步长nums[i]与之前的k中的较大值  // 这样,k就始终保持着从起点开始能够到达的最远位置k = Math.max(k, i + nums[i]);}// 如果在某一步中,k能够到达或超过数组的最后一个位置(nums.length-1),那么就可以从起点跳到终点  // 但是这里我们不需要立即返回true,因为还需要继续检查剩余的元素是否有更远的跳跃可能性  // 只有在遍历完整个数组后,都没有返回false,才说明可以从起点跳到终点// 如果能够遍历完整个数组而没有返回false,那么说明可以从起点跳到终点return true;}

复杂度

时间复杂度: O(n),其中 n为数组的大小。只需要访问 nums 数组一遍,共 n 个位置。
空间复杂度:O(1),不需要额外的空间开销。

总结

dp思想还是很值得学习的,结合昨天的最大子数组再看看想想画画,加深理解,下次再做相似的题就可以下手了。那么这道题就先到这儿啦!再见

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

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

相关文章

mysql中optimizer trace的作用

大家好。对于MySQL 5.6以及之前的版本来说&#xff0c;查询优化器就像是一个黑盒子一样&#xff0c;我们只能通过EXPLAIN语句查看到最后 优化器决定使用的执行计划&#xff0c;却无法知道它为什么做这个决策。于是在MySQL5.6以及之后的版本中&#xff0c;MySQL新增了一个optimi…

我国液碱产量逐渐增长 行业集中度有望不断提升

我国液碱产量逐渐增长 行业集中度有望不断提升 液碱是由氢氧化钠&#xff08;NaOH&#xff09;、氢氧化钾&#xff08;KOH&#xff09;等化合物以及水组成的一种碱性化合物。液碱的相对分子质量为40.00&#xff0c;密度为1.318g/cm&#xff0c;在常温常压下多表现为一种无色、无…

12 - 常用类

那就别跟他们比&#xff0c;先跟自己比&#xff0c;争取今天比昨天强一些&#xff0c;明天比今天强一些。 1.包装类 针对八种基本数据类型封装的相应的引用类型。 有了类的特点&#xff0c;就可以调用类中的方法。&#xff08;为什么要封装&#xff09; 基本数据类型包装类b…

JavaSE——学习总结

一、初识Java 运行Java程序 Java是一门半编译型、半解释型语言 先通过javac编译程序把源文件进行编译&#xff0c;编译后生成的.class文件是由字节码组成的&#xff0c;和平台无关、面向JVM的文件&#xff0c;最后启动java虚拟机来运行.class文件&#xff0c;此时JVM会将字节…

目标检测数据集 - 城市道路行驶车辆检测数据集下载「包含VOC、COCO、YOLO三种格式」

​​​数据集介绍&#xff1a;城市道路行驶车辆检测数据集&#xff0c;真实监控场景高质量图片数据&#xff0c;涉及场景丰富&#xff0c;比如城市道路快速行驶车辆、城市道路慢速行驶车辆、城市道路密集行驶车辆、城市道路夜间低光行驶车辆数据等。数据集标注标签划分为 "…

python-字符替换

[题目描述] 给出一个字符串 s 和 q 次操作&#xff0c;每次操作将 s 中的某一个字符a全部替换成字符b&#xff0c;输出 q 次操作后的字符串输入 输入共 q2 行 第一行一个字符串 s 第二行一个正整数 q&#xff0c;表示操作次数 之后 q 行每行“a b”表示把 s 中所有的a替换成b输…

使用kubespray部署k8s生产环境

使用kubespray部署k8s生产环境 系统环境 OS: Static hostname: test Icon name: computer-vm Chassis: vm Machine ID: 22349ac6f9ba406293d0541bcba7c05d Boot ID: 83bb7e5dbf27453c94ff9f1fe88d5f02 Virtualization: vmware Operating System: Ubuntu 22.04.4 LTS Kernel: L…

mac M1下安装PySide2

在M1下装不了PySide2, 是因为PySide2没有arm架构的包 1 先在M1上装qt5 安装qt主要是为了能用里面的Desinger, uic, rcc brew install qt5 我装完的路径在/opt/homebrew/opt/qt5 其中Designer就是用来设计界面的 rcc用resource compiler, 编绎rc资源文件的, 生成对应的py文件…

JZ2440笔记:热插拔驱动

&#xff08;1&#xff09;打印环境变量 vi lib/kobject_uevent.c 208 printk("feng: uevent_helper %s\n",uevent_helper); for(i0;envp[i];i) {printk("envp[%d] %s\n",i,envp[i]); } 使用修改后的uImage启动&#xff0c;测试打印应用程序的环境变量…

Unit8

Unit8 1. lect 选择&#xff0c;收集 collect collector collection collective select selected selection elect election eligible intellect intellectual intelligence neglect negligible negligence 2. long 长 long long for sth length lengthy lengthen be…

echarts legend. icon的展示

默认展示 icon展示circle圆形rect矩形roundRect圆角矩形triangle三角形diamond菱形pin水滴arrow箭头none不显示

Redis位图

简介 在我们平时开发过程中&#xff0c;会有一些bool型数据需要存取&#xff0c;比如用户一年的签到记录&#xff0c;签了是1&#xff0c;没签是0&#xff0c;要记录365天。如果使用普通的key/value&#xff0c;每个用户要记录365个&#xff0c;当用户上亿的时候&#xff0c;需…

资质延期后如何提升风景园林项目的质量

资质延期后&#xff0c;提升风景园林项目的质量是确保企业持续发展和市场竞争力的关键。以下是一些具体的建议&#xff0c;旨在帮助企业实现项目质量的提升&#xff1a; 一、科学规划和设计 注重项目前期调研&#xff1a;在项目开始之前&#xff0c;进行充分的市场调研和现场勘…

数据中心综合解决方案

安科瑞电气股份有限公司 祁洁 acrelqj 一、方案介绍 安科瑞电气紧跟数据中心发展形式&#xff0c;推出数据中心综合解决方案&#xff0c;集成了变配电监测、电源备自投、电气接点测温、智能照明控制、电能质量监测及治理、蓄电池在线监测、精密配电监控、智能母线监控以及消…

重要经济数据对行情的影响有多大?

金融市场上的消息非常多&#xff0c;可以来自不同国家、不同大型企业&#xff0c;也可以由不同机构统计公布&#xff0c;甚至是各国政府或中央银行的发表。在宏观经济层面上&#xff0c;所有政经消息都属于金融市场的风险事件&#xff0c;大多能引起市场波动&#xff0c;因此投…

MySQL里如果有字段是function怎么查询呢?

在MySQL中&#xff0c;字段名通常不会命名为function&#xff0c;因为FUNCTION是MySQL的保留关键字&#xff0c;用于定义存储函数。但是&#xff0c;如果你确实有一个字段名叫做function&#xff08;尽管这通常不是一个好的实践&#xff09;&#xff0c;你仍然可以查询它。你只…

android 开机动画执行流程

android深入了解开机动画 开机动画的种类 1&#xff1a;View绘制 2&#xff1a;逐帧动画&#xff1a;比较主流的方式&#xff0c;一般动画的文件打包成 bootanimation.zip 存储到 /system/media/ 下。一般.zip文件 > 5M 就会有明显的卡顿&#xff0c;所以一般开机动画只有…

Python界面怎么下载

Python界面怎么下载 Python界面&#xff0c;通常指的是Python的集成开发环境&#xff08;IDE&#xff09;或图形用户界面&#xff08;GUI&#xff09;库所创建的窗口界面。对于初学者和开发者来说&#xff0c;选择一个合适的Python界面工具对于提高编程效率至关重要。然而&…

NoSuchModuleError: Can‘t load plugin: sqlalchemy.dialects:clickhouse解决方案

NoSuchModuleError: Cant load plugin: sqlalchemy.dialects:clickhouse解决方案:全面解析 问题概述 当您使用 SQLAlchemy 连接 ClickHouse 数据库时,遇到 NoSuchModuleError: Cant load plugin: sqlalchemy.dialects:clickhouse 错误时,这意味着无法加载 ClickHouse 方言…

正大国际期货:期货交易需要根除的几点习惯

1、交易过多品种。对于期货交易而言&#xff0c;最不靠谱的就是同时操作多个品种。我认为的较合适的品种上限在3-4个&#xff0c;甚至更少为好。我们经常看到的截图&#xff0c;动辄十个甚至数十个品种&#xff0c;而且都盈利&#xff0c;这种截图看看就罢&#xff0c;不必认真…