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

相关推荐
闲人不梦卿几秒前
数组和矩阵以及广义表
数据结构
假女吖☌7 分钟前
限流算法-redis实现与java实现
java·redis·算法
u0109272718 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
蒟蒻的贤10 分钟前
两数之和。
算法
lixin55655616 分钟前
基于迁移学习的图像风格增强器
java·人工智能·pytorch·python·深度学习·语言模型
wen__xvn22 分钟前
代码随想录算法训练营DAY27第八章 贪心算法 part01
算法·贪心算法
阡陌..22 分钟前
浅谈SAR图像处理---形态学滤波
图像处理·人工智能·python
We་ct35 分钟前
LeetCode 125. 验证回文串:双指针解法全解析与优化
前端·算法·leetcode·typescript
客卿12338 分钟前
力扣20-有效括号(多家面试题)
算法·leetcode·职场和发展
木井巳1 小时前
【递归算法】快速幂解决 pow(x,n)
java·算法·leetcode·深度优先