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)。

相关推荐
郝学胜-神的一滴2 分钟前
人工智能发展漫谈:从专家系统到AIGC,再探深度学习核心与Pytorch入门
人工智能·pytorch·python·深度学习·算法·cnn·aigc
老杨_QQ1222090176 分钟前
对量化交易未来的思考
人工智能·python·金融
nananaij6 分钟前
【LeetCode-03 判断根结点是否等于子结点之和 python解法】
python·算法·leetcode
超级大只老咪8 分钟前
差分算法(java)
算法
逆境不可逃10 分钟前
【从零入门23种设计模式21】行为型之空对象模式
java·开发语言·数据库·算法·设计模式·职场和发展
老师好,我是刘同学10 分钟前
归并排序原理与Python实现详解
python·排序算法
超级大只老咪13 分钟前
输入(java)
算法
jing-ya15 分钟前
day51 图论part3
数据结构·算法·深度优先·图论
Dxy123931021620 分钟前
PyTorch的CyclicLR详细介绍:给模型训练装上“涡轮增压”
人工智能·pytorch·python
那小子、真烦26 分钟前
OpenClaw Skill 编写规范 与示例
python