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

相关推荐
深蓝电商API几秒前
Selenium Grid分布式执行爬虫任务
爬虫·python·selenium
Anastasiozzzz3 分钟前
常见限流算法--【令牌桶】【漏桶】【固定窗口】【滑动窗口】
java·redis·后端·算法·面试
凯酱7 分钟前
Java8 遍历List 使用stream().parallel()并发安全
数据结构·windows·list
独自破碎E9 分钟前
动态规划-打家劫舍I-II-III
算法·动态规划
云草桑10 分钟前
C#.net 分布式ID之雪花ID,时钟回拨是什么?怎么解决?
分布式·算法·c#·.net·雪花id
风筝在晴天搁浅12 分钟前
hot100 104.二叉树的最大深度
java·算法
潇冉沐晴13 分钟前
div3 970个人笔记
c++·笔记·算法
Just right14 分钟前
安装RAGAS遇到的问题
笔记·python
_Soy_Milk17 分钟前
【算法工程师】—— Python 数据分析
python·数据分析·numpy·pandas·matplotlib
历程里程碑17 分钟前
双指针1:移动零
大数据·数据结构·算法·leetcode·elasticsearch·搜索引擎·散列表