Leecode热题100---45:跳跃游戏②

题目

给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。

每个元素 nums[i] 表示从索引 i 向前跳转的最大长度

返回到达 nums[n - 1] 的最小跳跃次数。

思路

  1. 如果某一个作为 起跳点 的格子可以跳跃的距离是 3,那么表示后面 3 个格子都可以作为 起跳点。

    1.1. 可以对每一个能作为 起跳点 的格子都尝试跳一次,把 能跳到最远的距离 不断更新。

  2. 如果从这个 起跳点 起跳叫做第 1 次 跳跃,那么从后面 3 个格子起跳 都 可以叫做第 2 次 跳跃。

  3. 所以,当一次 跳跃 结束时,从下一个格子开始,到现在 能跳到最远的距离,都 是下一次 跳跃 的 起跳点。

    3.1. 对每一次 跳跃 用 for 循环来模拟。

    3.1.1跳完一次之后,更新下一次 起跳点 的范围。

    3.1.2在新的范围内跳,更新 能跳到最远的距离。

  4. 记录 跳跃 次数,如果跳到了终点,就得到了结果。

C++:

cpp 复制代码
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;

class Solution
{
public:
	int jump(vector<int>& nums)
	{
		int times = 0;
		int start = 0;
		int end = 1;
		int n =nums.size();
		while(end < n)
		{
			int maxPose = 0;
			for(int i = start; i<end; i++)
			{
				// 能跳到的最远距离
				maxPose = max(maxPose,i+nums[i]);
			}
			start = end;  // 下一次起跳范围开始的格子
			end = maxPose + 1;	// 下一次起跳范围结束的格子
			times++;
		}
		return times;
	}
};
相关推荐
图码几秒前
生命游戏的优雅解法:从O(mn)空间到O(1)空间的进阶之旅
数据结构·算法·游戏·矩阵·空间计算
薇茗18 分钟前
【初阶数据结构】 升沉有序的平仄 排序
c语言·数据结构·算法·排序算法
蝈理塘(/_\)大怨种1 小时前
快速排序的递归与非递归实现
数据结构·算法
qq_296553271 小时前
矩阵逆时针旋转90度:三种解法从入门到精通
数据结构·python·算法·面试·矩阵
努力努力再努力wz1 小时前
【Redis入门系列】Redis基础命令详解:从客户端连接到数据读写、key 管理与过期机制
c语言·开发语言·数据结构·数据库·c++·redis·缓存
谙弆悕博士1 小时前
【附C源码】C语言实现散列表
c语言·开发语言·数据结构·算法·散列表·数据结构与算法
LuminousCPP1 小时前
数据结构-线性表第一篇
数据结构·经验分享·笔记·顺序表
·心猿意码·2 小时前
OCCT源码解析(二):NCollection解析
数据结构·c++
gumichef2 小时前
栈和队列(2)
数据结构·算法·链表
许长安2 小时前
C++ 原子变量与内存序:从std::atomic到release/acquire
开发语言·数据结构·c++·经验分享·笔记