leetcode 45跳跃游戏II

简介: leetcode 45跳跃游戏II

跳跃游戏II


aa392204330c4cb6aff7cbbd1d29db89.png

a4f354f81417499a8ccd29f0530c67d0.png

核心思想:当前范围内走不到目的地,更新下一个范围。下一个范围是当前范围内能走到的最远点

class Solution {
public:
    int jump(vector<int>& nums) {
        if (nums.size() == 1) return 0;
        int cover = 0;    // 当前覆盖最远距离下标
        int step = 0;            // 记录走的最大步数
        int nextcover = 0;   // 下一步覆盖最远距离下标
        for (int i = 0; i < nums.size() && i <= cover; i++) 
        {
            nextcover = max(nums[i] + i, nextcover);  // 更新下一步覆盖最远距离下标
            if (i == cover) // 遇到当前覆盖最远距离下标
            {                         
                if (cover < nums.size() - 1) // 如果当前覆盖最远距离下标不是终点
                {       
                    step++;       // 需要走下一步
                    cover = nextcover;   // 更新当前覆盖最远距离下标
                    if (nextcover >= nums.size() - 1) break; // 下一步的覆盖范围已经可以达到终点,结束循环
                } 
                else break;       // 当前覆盖最远距离下标是集合终点,不用做ans++操作了,直接结束
            }
        }
        return step;
    }
};

二刷

class Solution {
public:
    int jump(vector<int>& nums) {
        int step = 0;
        int nextright = 0;
        int right = 0;
        for(int left=0 ; left<=right&&left<nums.size();left++)
        {
            nextright = max(nextright , left+nums[left]);
            if(left == right)
            {
                if(right != nums.size()-1)
                {
                    step++;
                    right = nextright;
                    if(nextright >= nums.size()-1) break;
                }else break;
            }
        }
        return step;
    }
};
相关文章
|
3月前
|
算法
Leetcode第45题(跳跃游戏II)
这篇博客文章讨论了如何使用贪心算法解决LeetCode第45题“跳跃游戏II”,目的是找到使用最少跳跃次数到达数组末尾的策略。
122 8
Leetcode第45题(跳跃游戏II)
|
5月前
|
算法
LeetCode第55题跳跃游戏
LeetCode第55题"跳跃游戏"的解题方法,通过记录当前最远可达到的位置并判断每个位置是否可达以及能否到达末尾,有效解决了跳跃至数组末尾的可行性问题。
LeetCode第55题跳跃游戏
|
3月前
Leetcode第55题(跳跃游戏)
LeetCode第55题“跳跃游戏”要求判断在一个非负整数数组中,从第一个位置出发,是否能够到达最后一个位置,其中每个位置的元素代表可跳跃的最大长度。
38 0
|
5月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
61 1
|
5月前
|
Python
【Leetcode刷题Python】174. 地下城游戏
LeetCode 174题 "地下城游戏" 的Python解决方案,使用动态规划算法计算骑士从左上角到右下角拯救公主所需的最低初始健康点数。
59 3
|
5月前
|
算法 索引 Python
【Leetcode刷题Python】55. 跳跃游戏
解决LeetCode "跳跃游戏"问题的Python实现代码,使用了贪心算法的思路。代码中初始化最远可到达位置 max_k,并遍历数组 nums,通过更新 max_k 来记录每次能跳到的最远位置,如果在任何时刻 max_k 大于或等于数组的最后一个索引,则返回 True,表示可以到达数组的末尾;如果当前索引 i 超出了 max_k,则返回 False,表示无法继续前进。时间复杂度为 O(n),空间复杂度为 O(1)。
59 1
|
5月前
|
算法
LeetCode第45题跳跃游戏 II
LeetCode第45题"跳跃游戏 II"的解题方法,通过一次循环和选择每个位置的最大可跳距离,有效减少了跳跃次数,简化了问题。
|
7月前
|
算法
力扣经典150题第三十八题:生命游戏
力扣经典150题第三十八题:生命游戏
65 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
137 2