213.贪心算法:跳跃游戏||(力扣)

class Solution {
public:
    int jump(vector<int>& nums) 
    {
        if (nums.size() == 1) return 0; // 如果数组长度为1,已经在终点,不需要跳跃

        int cur = 0;   // 当前跳跃能到达的最远位置
        int flag = 0;  // 记录跳跃次数
        int next = 0;  // 下一次跳跃能到达的最远位置
        
        for (int i = 0; i < nums.size(); i++)
        {
            next = max(i + nums[i], next); // 更新下一次跳跃能到达的最远位置
            
            if (i == cur) // 当遍历到当前跳跃的最远位置时
            {
                flag++;   // 增加跳跃次数
                cur = next; // 更新当前跳跃的最远位置
                
                if (next >= nums.size() - 1) break; // 如果下一次跳跃能到达终点,结束循环
            }
        }
        
        return flag; // 返回跳跃次数
    }
};

核心思想

该算法使用贪心策略,每次选择当前能跳跃的最远位置,并更新下一次能跳跃的最远位置。遍历过程中,每当到达当前能跳跃的最远位置时,增加跳跃次数,并更新当前跳跃能到达的最远位置。如果在更新过程中,发现能到达或超过终点,跳出循环。

示例

考虑 nums = [2, 3, 1, 1, 4]

  • 初始 cur = 0flag = 0next = 0
  • 第一次循环:
    • i = 0next = max(0 + 2, 0) = 2
    • i == cur,跳跃次数增加:flag = 1,更新 cur = next = 2
  • 第二次循环:
    • i = 1next = max(1 + 3, 2) = 4
    • i == cur,跳跃次数增加:flag = 2,更新 cur = next = 4
    • 终点可达,跳出循环

最终返回 flag = 2,表示最少需要跳跃两次。

相关推荐

  1. 贪心题解 跳跃游戏

    2024-07-09 19:30:07       53 阅读
  2. 贪心算法-跳跃游戏

    2024-07-09 19:30:07       34 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-09 19:30:07       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-09 19:30:07       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-09 19:30:07       57 阅读
  4. Python语言-面向对象

    2024-07-09 19:30:07       68 阅读

热门阅读

  1. go语言hassuffix的简单使用

    2024-07-09 19:30:07       31 阅读
  2. Vim常用整理快捷键

    2024-07-09 19:30:07       24 阅读
  3. Elasticsearch 分析器(Analyzer)的作用和配置

    2024-07-09 19:30:07       20 阅读
  4. html5 video去除边框

    2024-07-09 19:30:07       17 阅读
  5. 机器学习模型运用在机器人上

    2024-07-09 19:30:07       23 阅读
  6. 在网站存在漏洞的情况下强化安全防御

    2024-07-09 19:30:07       23 阅读
  7. 驱动开发系列-如何与硬件通信

    2024-07-09 19:30:07       27 阅读
  8. 计算机网络笔记分享(第六章 应用层)

    2024-07-09 19:30:07       33 阅读
  9. QT配置opencv

    2024-07-09 19:30:07       29 阅读