LeetCode in Python 55. Jump Game (跳跃游戏)

跳跃游戏的游戏规则比较简单,若单纯枚举所有的跳法以判断是否能到达最后一个下标需要的时间复杂度为O(),为此,本文采用贪心策略,从最后一个下标开始逆着向前走,若能跳到第一个元素则表明可以完成跳跃游戏,反之不能。此方法只需遍历一次数组,时间复杂度为O(n)。

示例:

图1 跳跃游戏输入输出示例

代码:

python 复制代码
class Solution:
    def canJump(self, nums):
        goal = len(nums) - 1
        for i in range(len(nums) - 1, -1, -1):
            if i + nums[i] >= goal:
                goal = i
        if goal == 0:
            return True
        else:
            return False

解释:

1)goal初始为最后一个下标,其代表需要跳入的目标位置。从最后一个位置开始往前跳,如果前一个位置(i)+前一个位置可以跳的最大长度(nums[i])>=goal,表明可以从前一个位置跳到目标位置。如此一来,即可将目标位置更新为前一个位置,如此往复,直到goal==0,即可以跳到第一个位置,表明完成跳跃游戏,反之不能。时间复杂度由枚举法的O()降至O(n)。

相关推荐
workflower8 分钟前
原子需求的属性
python·测试用例·需求分析·软件需求
重生之后端学习19 分钟前
78. 子集
java·数据结构·算法·职场和发展·深度优先
摸鱼仙人~25 分钟前
0-1背包与完全背包:遍历顺序背后的秘密
人工智能·算法
尘缘浮梦26 分钟前
协程asyncio入门案例 2
开发语言·python
juleskk28 分钟前
2.15 复试训练
开发语言·c++·算法
kronos.荒29 分钟前
滑动窗口+哈希表:最小覆盖子串
数据结构·python·散列表
那起舞的日子31 分钟前
斐波那契数列
java·算法
AC赳赳老秦33 分钟前
文旅AI趋势:DeepSeek赋能客流数据,驱动2026智慧文旅规模化跃迁
人工智能·python·mysql·安全·架构·prometheus·deepseek
wostcdk1 小时前
筛质数汇总
数据结构·算法
一个处女座的程序猿O(∩_∩)O1 小时前
Python面向对象的多态特性详解
开发语言·python