当前位置: 首页 > news >正文

Leetcode_45:跳跃游戏 II

题目描述:

给定一个长度为 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 <= 104
  • 0 <= nums[i] <= 1000
  • 题目保证可以到达 nums[n-1]

思路:

①首先是判断数组的长度。如果数组的长度小于或者等于1,则返回0,因为此时已经处在最后一个位置;

②每到一个位置 i 时,跳跃的范围是从 [ i+1 , i+nums[i] ] ,i+1 表示的是左边界,跳最小距离 1;i + nums [ i ] 表示右边界,跳最大距离 i + nums [ i ],每次跳跃的最优解是右边界最大,即需要最短的次数即可达到最后位置。

代码:

class Solution(object):def jump(self, nums):""":type nums: List[int]:rtype: int"""n = len(nums)if n <= 1:return 0step = 1left, right = 1, nums[0]while right < n - 1:for i in range(left, right + 1):if i + nums[i] > right:right = i + nums[i]left = i + 1step += 1return stepif __name__ == "__main__":nums = [2, 1]a = Solution()print(a.jump(nums))

http://www.lryc.cn/news/237705.html

相关文章:

  • 给新手教师的成长建议
  • 新手教师如何迅速成长
  • 竞赛选题 深度学习验证码识别 - 机器视觉 python opencv
  • 提升工作效率,使用AnyTXT Searcher实现远程办公速查公司电脑文件——“cpolar内网穿透”
  • mybatis使用foreach标签实现union集合操作
  • 请问DasViewer是否支持与业务系统集成,将业务的动态的数据实时的展示到三维模型上?
  • [ruby on rails]rack-cors, rack-attack
  • 猫12分类:使用多线程爬取图片的Python程序
  • 《深度学习500问》外链笔记
  • 机器学习技术栈—— 概率学基础
  • 使用Redis实现分布式锁
  • linux 服务器进程、端口查找,nginx 配置日志查找,lsof 命令详解
  • 汽车标定技术--A2L格式分析
  • Linux操作系统使用及C高级编程-D9D10Linux 服务搭建与使用
  • git下载安装配置及Git在Gitee上拉取和上传代码教程
  • ospf路由选路及路由汇总
  • Oracle 11g 多数据库环境下的TDE设置
  • vue3使用pinia实现数据缓存
  • 【CSS】min 和 max 函数(设置最大最小值)
  • ip地址跟wifi有关系吗
  • [算法学习笔记](超全)概率与期望
  • SpringCloud相关
  • 在 Linux 和 Windows 系统下查看 CUDA 和 cuDNN 版本的方法,包括使用 nvcc 命令
  • 4.10每日一题(二元函数极值相关重要性质,反复学习)
  • idea项目中java类名出现带 j 小红点,如何解决?
  • 生产环境_移动目标轨迹压缩应用和算法处理-Douglas-Peucker轨迹压缩算法
  • HINSTANCE是什么?
  • uniapp小程序定位;解决调试可以,发布不行的问题
  • C++学习 --pair
  • Android Frgment中onActivityResult无效的问题