【算法|贪心算法系列No.4】leetcode55. 跳跃游戏 45. 跳跃游戏 II
个人主页:兜里有颗棉花糖
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创
收录于专栏【手撕算法系列专栏】【LeetCode】
🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望对大家有所帮助
🍓希望我们一起努力、成长,共同进步。
目录
- 一、55. 跳跃游戏
- 1️⃣题目描述
- 2️⃣题目解析
- 3️⃣解题代码
- 二、45. 跳跃游戏 II
- 1️⃣题目描述
- 2️⃣题目解析
- 3️⃣解题代码
一、55. 跳跃游戏
点击直接跳转到该题目
1️⃣题目描述
给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。
示例1:
输入:nums = [2,3,1,1,4]
输出:true
解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。
示例2:
输入:nums = [3,2,1,0,4]
输出:false
解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。
注意:
- 1 <= nums.length <= 1 0 4 10^{4} 104
- 0 <= nums[i] <= 1 0 5 10^{5} 105
2️⃣题目解析
解题思路:
维护一个可达到的最远位置maxPos,通过遍历当前可跳跃范围内的所有位置,计算每个位置能够达到的最远位置,并更新maxPos。如果maxPos超过数组长度的最后一个位置,则表示可以到达末尾,返回true;否则,根据当前位置调整下一次可跳跃范围的起点和终点,直到无法继续跳跃返回false。
3️⃣解题代码
class Solution {
public:bool canJump(vector<int>& nums) {int n = nums.size(),left = 0,right = 0,maxPos = 0;while(left <= right){if(maxPos >= n - 1) return true;for(int i = left;i <= right;i++)maxPos = max(maxPos,i + nums[i]);left = right + 1,right = maxPos;}return false;}
};
最后就顺利通过啦!!!
二、45. 跳跃游戏 II
点击直接跳转到该题目
1️⃣题目描述
给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。
每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:
0 <= j <= nums[i]i + j < n
返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。
示例1:
输入: nums = [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。
示例2:
输入: nums = [2,3,0,1,4]
输出: 2
注意:
- 1 <= nums.length <= 1 0 4 10^{4} 104
0 <= nums[i] <= 1000- 题目保证可以到达 nums[n-1]
2️⃣题目解析
解题思路:
每次在当前能跳跃范围内选择可以使得接下来能跳跃最远的位置,不断更新可跳跃范围和最远位置,直到到达最后一个位置。时间复杂度为O(n),其中n为数组长度。
3️⃣解题代码
class Solution {
public:int jump(vector<int>& nums) {int n = nums.size(),left = 0,right = 0,maxPos = 0,cnt = 0;while(left <= right && maxPos < n - 1){cnt++;for(int i = left;i <= right;i++)maxPos = max(maxPos,i + nums[i]);left = right + 1,right = maxPos;}return cnt;}
};
最后就顺利通过啦!!!
相关文章:
【算法|贪心算法系列No.4】leetcode55. 跳跃游戏 45. 跳跃游戏 II
个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【LeetCode】 🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望…...
第九章 JDBC
文章目录 一. 单选题(共5题,50分)二. 判断题(共5题,50分) 一. 单选题(共5题,50分) (单选题) 下列选项,可用于存储结果集的对象是() A.…...
Kubernetes基础概念及架构和组件
目录 一、kubernetes简介 1、kubernetes的介绍与作用 2、为什么要用K8S? 二、kubernetes特性 1、自我修复 2、弹性伸缩 3、服务发现和负载均衡 4、自动发布(滚动发布/更新)和回滚 5、集中化配置管理和密钥管理 6、存储编排 7、任务批…...
04.Finetune vs. Prompt
目录 语言模型回顾大模型的两种路线专才通才二者的比较 专才养成记通才养成记Instruction LearningIn-context Learning 自动Prompt 部分截图来自原课程视频《2023李宏毅最新生成式AI教程》,B站自行搜索 语言模型回顾 GPT:文字接龙 How are __. Bert&a…...
UG NX二次开发(C#)-采用NXOpen完成对象的合并操作
文章目录 1、前言2、Ufun实现布尔和操作的函数2.1 函数说明2.2 源代码3、采用NXOpen实现布尔和操作的函数3.1 函数说明3.2 源代码4、测试结果4.1 采用UFun 与NXOpen的结果4.2采用UFun 与NXOpen的对比说明1、前言 在UG NX中开发过程中,创建特征对象的时候往往会用到布尔操作,…...
测开不得不会的python之re模块正则表达式匹配
学习目录 正则表达式介绍 正则表达式的常用符号 python的re模块 findall()函数 finditer()函数 match()函数 search()函数 split()函数 正则表达式的介绍 Python 通过标准库中的 re 模块来支持正则表达式。 正则表达式作为高级的文本模式匹配、抽取、和搜索。简单地说…...
selenium4 元素定位
selenium4 9种元素定位 ID driver.find_element(By.ID,"kw")NAME driver.find_element(By.NAME,"tj_settingicon")CLASS_NAME driver.find_element(By.CLASS_NAME,"ipt_rec")TAG_NAME driver.find_element(By.TAG_NAME,"area")LINK_T…...
sql高级教程-索引
文章目录 架构简介1.连接层2.服务层3.引擎层4.存储层 索引优化背景目的劣势分类基本语法索引结构和适用场景 性能分析MySq| Query Optimizerexplain 索引优化单表优化两表优化三表优化 索引失效原因 架构简介 1.连接层 最上层是一些客户端和连接服务,包含本地sock通…...
拼团小程序制作技巧大揭秘:零基础也能轻松掌握
随着拼团模式的日益流行,越来越多的商家和消费者开始关注拼团小程序的制作。对于没有技术背景的普通人来说,制作一个拼团小程序似乎是一项艰巨的任务。但实际上,选择一个简单易用的第三方平台或工具,可以轻松完成拼团小程序的制作…...
报错:The supplied javaHome seems to be invalid. I cannot find the java executable
AS 升级遇到的问题 问题 升级 Android Studio,碰到无法检测到 java The supplied javaHome seems to be invalid. I cannot find the java executable. Tried location: D:\Program Files\Android\Android Studio\jre\bin\java.exe 然后去网上找解决思路。 终于…...
关于 硬盘
关于 硬盘 1. 机械硬盘1.1 基本概念1.2 工作原理1.3 寻址方式1.4 磁盘磁记录方式 2. 固态硬盘2.1 基本概念2.2 工作原理 1. 机械硬盘 1.1 基本概念 机械硬盘即是传统普通硬盘,硬盘的物理结构一般由磁头与盘片、电动机、主控芯片与排线等部件组成。 所有的数据都是…...
Java反射实体组装SQL
之前在LIS.Core定义了实体特性,在LIS.Model给实体类加了表特性,属性特性,外键特性等。ORM要实现增删改查和查带外键的父表信息就需要解析Model的特性和实体信息组装SQL来供数据库驱动实现增删改查功能。 实现实体得到SQL的工具类,…...
tensorrt安装使用教程
一般的深度学习项目,训练时为了加快速度,会使用多GPU分布式训练。但在部署推理时,为了降低成本,往往使用单个GPU机器甚至嵌入式平台(比如 NVIDIA Jetson)进行部署,部署端也要有与训练时相同的深…...
Java后端开发(十)-- idea(2022版)将 已push 的 远程仓库 的 多条commit记录 进行撤销
目录 1.多次 修改Test01类后,提交到本地仓库 。 2.多次重复 1 的步骤,多次commit成功后,在Git =》Log中会显示,commit记录...
常见面试题-Netty专栏(一)
typora-copy-images-to: imgs Netty 是什么呢?Netty 用于做什么呢? 答: Netty 是一个 NIO 客户服务端框架,可以快速开发网络应用程序,如协议服务端和客户端,极大简化了网络编程,如 TCP 和 UDP …...
【iOS】JSONModel的基本使用
文章目录 前言一、导入JSONModel二、JSONModel的基本使用1.基本用法2.模型集合3.模型导出为NSDictionary或JSON4.设置所有属性可选(所有属性值可以为空)5.下划线(蛇式)转驼峰命名法 前言 JSONModel 是一个用于 Objective-C 的开源库,它用于简…...
imu预积分学习(更新中)
imu预积分学习(更新中) IMU预积分可以做什么? 以上面那个经典图片为例子,IMU可以通过六轴数据,拿到第i帧和第j帧之间的相对位姿,这样不就可以去用来添加约束了吗 但是有一个比较大的问题是: I…...
算法刷题-链表
算法刷题-链表 203. 移除链表元素 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val val 的节点,并返回 新的头节点 。 示例 1: 输入:head [1,2,6,3,4,5,6], val 6 输出:[1,2,3,4,5]…...
Linux 挂载磁盘到指定目录
问题:公司分配了数据磁盘,但是分区也没有挂载到目录 首先 df -h 查看一下挂载点的情况 查看服务器上未挂载的磁盘 fdisk -l 注:图中sda、sdb (a、b指的是硬盘的序号) 分区操作 我们可以看到b硬盘有536G未分区&…...
ZYNQ linux调试LCD7789
一,硬件管脚 1,参数解释和实物 LVGL是一个开源的图形库,主要用于MCU上屏幕UI的部署,功能完善,封装合理,可裁切性强,也可以实现Linux上fbx的部署。LVGL官网LVGL - Light and Versatile Embedded Graphics Library 每根线的作用...
如何快速掌握PDF差异对比工具:diff-pdf终极指南
如何快速掌握PDF差异对比工具:diff-pdf终极指南 【免费下载链接】diff-pdf A simple tool for visually comparing two PDF files 项目地址: https://gitcode.com/gh_mirrors/di/diff-pdf 你是否曾为PDF文档的版本管理而头疼?面对两份相似的PDF文…...
如何调用Qwen2.5-7B API?Python接入详细步骤
如何调用Qwen2.5-7B API?Python接入详细步骤 想用上阿里最新开源的Qwen2.5-7B-Instruct模型,但不知道从哪里开始?这篇文章就是为你准备的。我会带你从零开始,一步步用Python调用这个模型的API,让你快速上手࿰…...
ModbusRTU读取报文调试实战:用C#和Modbus Poll/Slave仿真器一步步抓包分析
ModbusRTU报文调试实战:从抓包分析到C#代码验证 当你第一次面对ModbusRTU协议时,那些十六进制数字组成的报文可能看起来像天书。但别担心,每个工业通信专家都曾经历过这个阶段。本文将带你用最直观的方式——抓包分析,来彻底理解M…...
深度解析Windows 11系统优化:3大高效修复策略实战指南
深度解析Windows 11系统优化:3大高效修复策略实战指南 【免费下载链接】ExplorerPatcher This project aims to enhance the working environment on Windows 项目地址: https://gitcode.com/GitHub_Trending/ex/ExplorerPatcher Windows 11更新后࿰…...
软件测试中的职业成长:覆盖率 vs 创新力
在软件测试领域,职业成长始终是从业者关注的核心议题。随着数字化转型加速,软件质量成为企业竞争力的关键支柱,测试工程师的角色从单纯的缺陷发现者向质量赋能者转变。然而,这一转型过程中,一个根本性矛盾日益凸显&…...
2026最权威的AI科研神器推荐榜单
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek AI写作软件是智能工具,它基于自然语言处理跟深度学习技术,有着辅助用…...
小白也能懂!Qwen3-Reranker-0.6B快速部署与WebUI调用实战
小白也能懂!Qwen3-Reranker-0.6B快速部署与WebUI调用实战 1. 为什么选择Qwen3-Reranker-0.6B Qwen3-Reranker-0.6B是Qwen家族最新推出的文本重排序模型,专为提升文本检索效果而设计。这个0.6B参数的模型虽然体积小巧,但在多语言文本排序任务…...
网络安全视角下的Qwen3-ForcedAligner服务防护策略
网络安全视角下的Qwen3-ForcedAligner服务防护策略 1. 语音对齐服务面临的真实安全挑战 在企业级AI语音处理系统中,Qwen3-ForcedAligner作为关键的语音强制对齐组件,承担着将语音与文本精确匹配、生成时间戳的核心任务。当它被部署为对外提供API服务时…...
OpenClaw hook-钩子机制详解
前言 OpenClaw 的钩子(Hook)系统是其核心扩展能力的载体,通过事件驱动的方式实现对代理(Agent)和网关(Gateway)全生命周期的灵活管控与深度集成。整个钩子系统清晰分为两大类——内部钩…...
终极指南:OBS智能背景移除插件让直播画面瞬间专业
终极指南:OBS智能背景移除插件让直播画面瞬间专业 【免费下载链接】obs-backgroundremoval An OBS plugin for removing background in portrait images (video), making it easy to replace the background when recording or streaming. 项目地址: https://gitc…...
