算法通关第十七关黄金挑战——透析跳跃问题

大家好,我是怒码少年小码。

本篇是贪心思想的跳跃问题专题,跳跃问题出现的频率很高。

跳跃游戏

LeetCode 55:给你一个非负整数数组 nums ,你最初位于数组的 第一个下标。数组中的每个元素代表你在该位置可以跳跃的最大长度。

判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。

示例 1:

  • 输入:nums = [2,3,1,1,4]

  • 输出:true

  • 解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。
    示例 2:

  • 输入:nums = [3,2,1,0,4]

  • 输出:false

  • 解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。

分析:这题的关键是要搞清楚题目的意思。如果当前位置的元素是3,那么你走1/2/3步,最后如果走到的数组中的最后一个位置就算你成功!

注意: 这里很容易就陷入到底具体是跳到哪一步、走多少步的思考漩涡中。这里的关键是能否走到终点。所以我们要尽可能的跳跃到最远的位置 ,看当前位置最多能覆盖到哪里,如果能覆盖到终点我们就赢了!

如下图:

第一个例子中,3能覆盖{2,1,0},2能覆盖{1,0},1能覆盖{0},而0不能覆盖到4,所以无法达到终点。

可见,第二个例子中有2种跳法{2,1,1,4},{2,3,1,1,4}。

定义一个变量cover表示当前位置可以覆盖的范围,遍历指针只能在cover中的范围变化,每次i变化都要引起cover的变化(cover会得到当前位置i的元素的补充),我们需要找到最远可以到达的位置,也就是需要在cover当前本身的值和补充之后的值之间,取一个最大值。

cover >= nums.length - 1时,说明可以成功。

java 复制代码
public boolean canJump(int[] nums) {
    if(nums.length == 1){
        return true;
    }
    int cover = 0 ;
    for(int i = 0 ; i<=cover;i++){
        cover = Math.max(cover , i+nums[i]);
        if(cover >= nums.length - 1){
            return true;
        }
    }
    return false;
}

最短跳跃问题

从上题可以看出一个数组有多种跳跃方式可以到达终点,那么最少需要几步能跳到终点呢?这就是LeetCode 45。

这题我们可以采用:贪心+双指针 的方法解决🤔。

  • left用于遍历数组
  • steps表示一共跳了多少步
  • right表示当前位置能够覆盖的最大范围

maxPosition = Math.max(maxPosition,left + nums[left]);这个还是最远能跳到哪里。当left == right说明当前区间最大覆盖区间已经寻找完毕。

例如上面的第一个例子:

java 复制代码
public int jump(int[] nums) {
  int right = 0 ;
  int steps = 0 ;
  int maxPosition = 0;
  for(int left = 0 ; left < nums.length - 1; left++){
      //最远能跳到哪里
      maxPosition = Math.max(maxPosition,left + nums[left]);
      if(left == right){ //left遍历到了边界,就更新边界并且步数加一
          right = maxPosition;
          steps++;
      }
      //right指针到了数组的最后
      if(right >= nums.length - 1){
          return steps;
      }
  }
  return steps;
}

END

今天这篇都是力扣上的中等难度,在面试的时候也挺常见的,多练练动手敲😎。

相关推荐
小沈熬夜秃头中୧⍤⃝4 分钟前
【贪心算法】No.1---贪心算法(1)
算法·贪心算法
木向36 分钟前
leetcode92:反转链表||
数据结构·c++·算法·leetcode·链表
阿阿越38 分钟前
算法每日练 -- 双指针篇(持续更新中)
数据结构·c++·算法
skaiuijing1 小时前
Sparrow系列拓展篇:对调度层进行抽象并引入IPC机制信号量
c语言·算法·操作系统·调度算法·操作系统内核
Star Patrick1 小时前
算法训练(leetcode)二刷第十九天 | *39. 组合总和、*40. 组合总和 II、*131. 分割回文串
python·算法·leetcode
武子康2 小时前
大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels
大数据·人工智能·python·深度学习·算法·机器学习·数据挖掘
m0_571957585 小时前
Java | Leetcode Java题解之第543题二叉树的直径
java·leetcode·题解
pianmian17 小时前
python数据结构基础(7)
数据结构·算法
好奇龙猫9 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_202410 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘