1.6 面试经典150题 - 跳跃游戏

跳跃游戏

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

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

python 复制代码
class Solution(object):
    
    def canJump(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        if not nums or len(nums) == 1: return True
        # 定义左右指针
        left = 0
        right = left + 1
        while right < len(nums):
            tmp_right = left
            # 计算本轮最有可以到达的位置
            for i in range(left, right):
                pos = i + nums[i]
                # 可以到达最后一个元素,提前返回
                if pos >= len(nums) - 1: return True
                if pos > tmp_right: tmp_right = pos
            # 本轮不能再向右了,返回false
            if tmp_right < right: return False
            # 更新两个指针值
            left = right
            right = tmp_right + 1
        return True

本题解题思路:

记录两个值:当前位置left,和目前可以到达的最右位置right

每次对区间内的位置进行遍历,找到新的 可以到达的最右位置

如果不能继续向右,则无法到达最后一个节点

如果可以,则更新left 和 right位置,继续遍历

跳跃游戏II

给定一个长度为 n0 索引 整数数组 nums。初始位置为 nums[0]

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

  • 0 <= j <= nums[i]
  • i + j < n

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]

python 复制代码
class Solution(object):
    def jump(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        if not nums or len(nums) == 1: return 0
        count = 0
        left = 0
        right = left + 1
        while right < len(nums):
            count += 1
            tmp_right = left
            for i in range(left, right):
                pos = i + nums[i]
                if pos >= len(nums) - 1: return count
                if pos > tmp_right: tmp_right = pos
            if tmp_right < right: return -1
            left = right
            right = tmp_right + 1
        return count

本题对上题略加修改,每次遍历都将计数加1,在上一题返回return的位置,变为返回计数即可。

相关推荐
FL16238631292 分钟前
基于yolo11实现的车辆实时交通流量进出统计与速度测量系统python源码+演示视频
开发语言·python·音视频
华如锦12 分钟前
四:从零搭建一个RAG
java·开发语言·人工智能·python·机器学习·spring cloud·计算机视觉
向阳蒲公英25 分钟前
Pycharm2025版本配置Anaconda步骤
python
Darkershadow31 分钟前
蓝牙学习之uuid与mac
python·学习·ble
北海有初拥34 分钟前
Python基础语法万字详解
java·开发语言·python
Mqh1807621 小时前
day61 经典时序模型3
python
我想吃烤肉肉1 小时前
logger比print优秀之处
python
Cosmoshhhyyy1 小时前
《Effective Java》解读第32条:谨慎并用泛型和可变参数
java·python
Cherry的跨界思维1 小时前
【AI测试全栈:Vue核心】19、Vue3+ECharts实战:构建AI测试可视化仪表盘全攻略
前端·人工智能·python·echarts·vue3·ai全栈·ai测试全栈
海棠AI实验室2 小时前
第十七章 调试与排错:读懂 Traceback 的方法论
python·pandas·调试