45. 跳跃游戏 II

文章目录

题目

贪心算法:45. 跳跃游戏 II

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

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在索引 i 处,你可以跳转到任意 (i + j) 处:

0 <= j <= nums[i] 且

i + j < n

返回到达 n - 1 的最小跳跃次数。测试用例保证可以到达 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

题目保证可以到达 n - 1

代码

cpp 复制代码
class Solution {
public:
    int jump(vector<int>& nums) {
        //还没跳之前,只能站在位置0。
        int left=0,right=0;
        int min_jumps=0;
        while(right<nums.size()-1)//只要当前层还没覆盖到终点,就继续再跳一次。
        {
            int farthest=0;
            for(int i=left;i<=right;++i)//左右都是闭区间
            {
                farthest=max(farthest,i+nums[i]);//跳的最远距离下标
            }
            left=right+1; //更新新区间为左边为右+1
            right=farthest;//右边更新为最远距离的下标
            ++min_jumps;//最小跳数+1
        }
        return min_jumps;
    }
};

原理图

原理解释

提示:算法流程及解释在代码中已标注

方法1:

枚举所有的跳跃方案,找出跳跃最少的,跳跃次数就是连接的条数。

实现方式是DFS

方法2:

寻找根节点到叶子几点的最短距离

使用BFS+剪枝加速寻找的过程

使用left和right来确定当前跳跃次数下,你能够到达的区间范围。

还没跳之前,left、right、min_jumps只能站在位置0。

循环条件:只要当前层还没覆盖到终点,就继续再跳一次。

相关推荐
澈20719 小时前
C++并查集:高效解决连通性问题
java·c++·算法
郝学胜-神的一滴20 小时前
Qt 入门 01-01:从零基础到商业级客户端实战
开发语言·c++·qt·程序人生·软件构建
宏笋20 小时前
C++ thread的detach()方法详解
c++
旖-旎20 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
大卡片1 天前
C++的基础知识点
开发语言·c++
米罗篮1 天前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程
谙弆悕博士1 天前
【附C++源码】从零开始实现 2048 游戏
java·c++·游戏·源码·项目实战·2048
沃普天科技1 天前
TYPE C全功能10G数据放大延长PS8353 PS8780 PS8778 8K60HZ
驱动开发·游戏·计算机外设·电脑·ar·硬件工程·vr
WiChP1 天前
【V0.1B9】从零开始的2D游戏引擎开发之路
c++·游戏引擎
Peter·Pan爱编程1 天前
从 struct 到 class:封装与访问控制的真正意义
c++