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

相关推荐
ybdesire8 分钟前
Joern服务器启动后cpgqls-client结合python编程进行扫描
运维·服务器·python
autho12 分钟前
conda
linux·python·conda
坚持就完事了14 分钟前
滑动窗口算法
数据结构
wuqingshun31415926 分钟前
蓝桥杯 缺页异常2【算法赛】
算法·职场和发展·蓝桥杯
知乎的哥廷根数学学派28 分钟前
基于注意力机制的多尺度脉冲神经网络旋转机械故障诊断(西储大学轴承数据,Pytorch)
人工智能·pytorch·python·深度学习·神经网络·机器学习
Mh_ithrha32 分钟前
题目:小鱼比可爱(java)
java·开发语言·算法
测试199833 分钟前
用Postman测WebSocket接口
自动化测试·软件测试·python·websocket·测试工具·接口测试·postman
l1t34 分钟前
数独优化求解C库tdoku-lib的使用
c语言·开发语言·python·算法·数独
有一个好名字35 分钟前
力扣-奇偶链表
算法·leetcode·链表
wxm63136 分钟前
力扣算法题(C++):1、2
java·算法·leetcode