leetcode 45. 跳跃游戏 II

这篇具有很好参考价值的文章主要介绍了leetcode 45. 跳跃游戏 II。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

2023.7.30

class Solution {
public:
    int jump(vector<int>& nums) {
        int step = 0;
        int cover = 0;
        int largest = 0;

        if(nums.size() == 1) return step;

        for(int i=0; i<nums.size(); i++)
        {
            cover = max(cover , i+nums[i]); //最大覆盖范围

            if(cover >= nums.size()-1) return step+1; 

            if(largest == i) //需要开始新的一步
            {
                step++;
                largest = cover;
            }
        }
        step++;
        return step;
    }
};

         本题为 跳跃游戏I 的升级版,保证可以到达终点的情况下,要求出最短的跳跃次数。

        还是仿照 跳跃游戏I 的思路,定义一个cover用于记录最大覆盖范围,终止条件是:        cover >= nums.size()-1  ,还要定义一个变量largest用于记录当前最远覆盖范围的下标,当i遍历到largest时,就要开始新的一步,即step++。

        下面看代码:文章来源地址https://www.toymoban.com/news/detail-621162.html

class Solution {
public:
    int jump(vector<int>& nums) {
        int step = 0;
        int cover = 0;
        int largest = 0;

        if(nums.size() == 1) return step;

        for(int i=0; i<nums.size(); i++)
        {
            cover = max(cover , i+nums[i]); //最大覆盖范围

            if(cover >= nums.size()-1) return step+1; //终止条件

            if(largest == i) //需要开始新的一步
            {
                step++;
                largest = cover;
            }
        }
        step++;
        return step;
    }
};

到了这里,关于leetcode 45. 跳跃游戏 II的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Golang | Leetcode Golang题解之第45题跳跃游戏II

    题目: 题解:

    2024年04月25日
    浏览(53)
  • Day32 贪心算法 part02 122. 买卖股票的最佳时机 II 55. 跳跃游戏 45. 跳跃游戏 II

    思路:计算每天的利润,利润如果为正,加到结果中去

    2024年01月19日
    浏览(44)
  • 跳跃游戏 + 45. 跳跃游戏 II

    给你一个非负整数数组  nums  ,你最初位于数组的  第一个下标  。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标,如果可以,返回  true  ;否则,返回  false  。 示例 1: 示例 2: 解析: 每次遍历,只需要贪心跳到最远即可

    2024年02月04日
    浏览(39)
  • 贪心 55. 跳跃游戏 45.跳跃游戏 II

    题目: 给定非负数组,初始位置在数组第一格,数组值是可以选择的最大跳跃步数,判断能不能达到数组末尾。 示例  1: * 输入: [2,3,1,1,4] * 输出: true * 解释: 我们可以先跳 1 步,从位置 0 到达 位置 1, 然后再从位置 1 跳 3 步到达最后一个位置。 示例  2: * 输入: [3,2,1,0,4] * 输出

    2024年03月21日
    浏览(46)
  • 代码随想录:55. 跳跃游戏;45. 跳跃游戏 II

    给定一个非负整数数组  nums  ,你最初位于数组的  第一个下标  。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标。 示例 1: 示例 2: 其实跳几步无所谓,关键在于可跳的覆盖范围! 不一定非要明确一次究竟跳几步,每次取最

    2023年04月11日
    浏览(47)
  • 跳跃游戏 II——力扣45

    题目描述 解法一 贪心

    2024年02月13日
    浏览(40)
  • 力扣:45. 跳跃游戏 II

    动态规划: 1.声明一个dp数组来表示到下标i时要跳转的最小次数,同时要个每个dp数组的值赋值为最大。之后初始化dp【0】=0,用for循环来进行遍历下标i和遍历下标i之前的值,判断条件为如果i之前的某个下标跳转的距离=i时要根新dp【i】的值 ,递推公式为dp【i】=math,min(dp[

    2024年02月20日
    浏览(37)
  • 力扣45. 跳跃游戏 II

    Problem: 45. 跳跃游戏 II Problem: 55.跳跃游戏 该题在上述的基础上,我们每次 先求取当前可跳区间内的最远距离farthest;每当走到当前的区间胃部时(end == i):跳跃步数加一(jumps++),同时将下一次的可跳的最远区间更新(end = farthest;) 时间复杂度: O ( n ) O(n) O ( n ) ;其中 n n n 为数组

    2024年02月22日
    浏览(56)
  • 【经典LeetCode算法题目专栏分类】【第5期】贪心算法:分发饼干、跳跃游戏、模拟行走机器人

    《博主简介》 小伙伴们好,我是阿旭。专注于人工智能AI、python、计算机视觉相关分享研究。 ✌ 更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍 感谢小伙伴 们点赞、关注! class   Solution :      def   findContentChildren ( self ,  g :  List [ int ],  s

    2024年02月04日
    浏览(52)
  • 代码随想录 第三十二天 45.跳跃游戏 II||122.买卖股票的最佳时机 II55. 跳跃游戏

    力扣题目链接(opens new window) 给定一个非负整数数组,你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个位置。 示例  1: 输入: [2,3,1,1,4] 输出: true 解释: 我们可以先跳 1 步,从位置 0 到达 位置 1, 然后再从位

    2024年02月15日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包