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

相关推荐
小兔崽子去哪了12 小时前
Python 数据分析环境搭建与工具使用指南
python
AI柠檬12 小时前
机器学习:数据集的划分
人工智能·算法·机器学习
不惑_13 小时前
Java 使用 FileOutputStream 写 Excel 文件不落盘?
开发语言·python
代码雕刻家13 小时前
1.4.课设实验-数据结构-单链表-文教文化用品品牌2.0
c语言·数据结构
IT小哥哥呀13 小时前
Python实用技巧:批量处理Excel数据并生成销售报表(含实战案例)
python·pandas·数据可视化·数据处理·报表生成·excel自动化·办公神器
让我们一起加油好吗13 小时前
【数论】裴蜀定理与扩展欧几里得算法 (exgcd)
算法·数论·裴蜀定理·扩展欧几里得算法·逆元
烤奶要加冰13 小时前
PyCharm 社区版全平台安装指南
ide·windows·python·pycharm·mac
Siren_dream13 小时前
anaconda与pycharm
ide·python·pycharm
whale fall13 小时前
Windows下PyCharm如何激活python的虚拟环境
ide·python·pycharm
Geo_V13 小时前
提示词工程
人工智能·python·算法·ai