Leetcode力扣45题 跳跃游戏 II
原题目:
跳跃游戏 II
给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
你的目标是使用最少的跳跃次数到达数组的最后一个位置。
示例:
输入: [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。
说明:
假设你总是可以到达数组的最后一个位置。
解法:
这道题希望用最少的次数完成跳跃,符合贪心的思维:局部最优,不可取消
我们选择当前能选择的走的最远的路径
具体实现
遍历数组,在遍历过程中,
使用一个变量表示当前能一步走到的最远点
使用一个变量记录当前步骤中,下一步能最远到达的点
使用一个变量表示当前走的步数
首先规定程序如何“选择”出了最远的步
我们在遍历数组的过程中,记录了当前步骤能一步到达的最远的点,
无论我们在这个步骤中选择下一步走哪个,我们在循环到当前能一步走到的最远点时,我们一定能得到:走完了一步、下一步能一步到达的最远点。
如此遍历完数组,就得到了答案
class Solution {
    public int jump(int[] nums) {
    int end = 0;
    int maxPosition = 0;
    int steps = 0;
    for(int i = 0; i < nums.length - 1; i++){
        //找能跳的最远的
        maxPosition = Math.max(maxPosition, nums[i] + i);
        if( i == end){ //遇到边界,就更新边界,并且步数加一
            end = maxPosition;
            steps++;
        }
    }
    return steps;
}
}
												
											Leetcode力扣45题 跳跃游戏 II的更多相关文章
- LeetCode 45. 跳跃游戏 II | Python
		
45. 跳跃游戏 II 题目来源:https://leetcode-cn.com/problems/jump-game-ii 题目 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素 ...
 - [leetcode] 45. 跳跃游戏 II(Java)(动态规划)
		
45. 跳跃游戏 II 动态规划 此题可以倒着想. 看示例: [2,3,1,1,4] 我们从后往前推,对于第4个数1,跳一次 对于第3个数1,显然只能跳到第4个数上,那么从第3个数开始跳到最后需要两次 ...
 - Java实现 LeetCode 45 跳跃游戏 II(二)
		
45. 跳跃游戏 II 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 示例: 输入: [ ...
 - leetcode 55. 跳跃游戏 及 45. 跳跃游戏 II
		
55. 跳跃游戏 问题描述 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1, ...
 - lintcode: 跳跃游戏 II
		
跳跃游戏 II 给出一个非负整数数组,你最初定位在数组的第一个位置. 数组中的每个元素代表你在那个位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 样例 给出数组A = ...
 - 力扣Leetcode 45. 跳跃游戏 II - 贪心思想
		
这题是 55.跳跃游戏的升级版 力扣Leetcode 55. 跳跃游戏 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 你的目标是使用最少的跳跃 ...
 - LeetCode(45): 跳跃游戏 II
		
Hard! 题目描述: 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 你的目标是使用最少的跳跃次数到达数组的最后一个位置. 示例: 输入: [ ...
 - [LeetCode] 45. Jump Game II 跳跃游戏 II
		
Given an array of non-negative integers, you are initially positioned at the first index of the arra ...
 - 【LeetCode每天一题】Jump Game II(跳跃游戏II)
		
Given an array of non-negative integers, you are initially positioned at the first index of the arra ...
 
随机推荐
- Python一键转Jar包,Java调用Python新姿势!
			
粉丝朋友们,不知道大家看故事看腻了没(要是没腻可一定留言告诉我^_^),今天这篇文章换换口味,正经的来写写技术文.言归正传,咱们开始吧! 本文结构: 需求背景 进击的Python Java和Pytho ...
 - python自动化第一课 - python安装以及pycharm配置
			
1.安装python 1.1打开python官网https://www.python.org/downloads/windows/进行下载Python 3.8.0 1.2下载完毕后进行安装,1勾选 A ...
 - Java继承中构造器的调用原理
			
Java的继承是比较重要的特性,也是比较容易出错的地方,下面这个例子将展示如果父类构造器中调用被子类重写的方法时会出现的情况: 首先是父类: public class test { void fun( ...
 - 为企业提供存储功能的Red Hat Stratis 2.0.1发布了
			
导读 Red Hat的Stratis存储项目用于在Linux上提供企业存储功能,以与ZFS和Btrfs之类的产品竞争,同时在LVM和XFS之上构建,这是其2020年守护进程的首次更新. 通过Strat ...
 - const 详解
			
 简单分类: 常变量 const 类型 变量名 或者 类型 const 变量名 常引用 const 类型& 引用名 ...
 - 【WPF学习】第五十九章 理解控件模板
			
最近工作比较忙,未能及时更新内容,敬请了解!!! 对于可视化树的分析引出了几个有趣问题.例如,控件如何从逻辑树表示扩张成可视化树表示? 每个控件都有一个内置的方法,用于确定如何渲染控件(作为一组更基础 ...
 - Python - 函数形参之必填参数、缺省参数、可变参数、关键字参数的详细使用
			
Python函数形参 必传参数:平时最常用的,必传确定数量的参数 缺省参数:在调用函数时可以传也可以不传,如果不传将使用默认值 可变参数:可变长度参数 关键字参数:长度可变,但是需要以kv对形式传参 ...
 - mysqli_query($conn, "set names utf8"); //**设置字符集*** 不设置插入数据库就是乱码
			
mysqli_query($conn, "set names utf8"); //**设置字符集*** 不设置插入数据库就是乱码
 - nested exception is java.lang.StackOverflowError解析
			
背景介绍: 项目是微服务的,使用docker容器,使用jenkins部署.测试环境有个公共服务一直以来都能正常发布,突然有一天不行了,经常发布失败,然后多发布几次就好了. 报错如下: 是栈溢出了,一般 ...
 - Mass Spectrometry-Compatible Subcellular Fractionation for Proteomics 质谱兼容的蛋白质组学的亚细胞分离(解读人:王茹凯)
			
文献名:Mass Spectrometry-Compatible Subcellular Fractionation for Proteomics(质谱兼容的蛋白质组学的亚细胞分离) 期刊名:Jpor ...