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

相关推荐
Greyson11 天前
实现 Flex 容器内子元素自适应高度并启用自动滚动
jvm·数据库·python
m0_596406371 天前
Redis如何配置主从复制关系_利用REPLICAOF命令将节点挂载至主节点
jvm·数据库·python
Ulyanov1 天前
《PySide6 GUI开发指南:QML核心与实践》 第八篇:性能优化大师——QML应用性能调优实战
python·qt·ui·性能优化·qml·系统仿真
2501_914245931 天前
如何处理Java应用重启导致的Oracle死锁_应用异常中断未释放锁与PMON清理延迟
jvm·数据库·python
橘白3161 天前
GVHMR
人工智能·算法·机器人·机器人数据·视频动捕
Gerardisite1 天前
私域运营新利器:RPA驱动外部群多模态互动
java·人工智能·python·微信·自动化
宵时待雨1 天前
优选算法专题3:二分查找
数据结构·c++·算法·leetcode·职场和发展
代码飞一会儿1 天前
算法与数据结构之树——让数据查找更加迅速
算法
工业甲酰苯胺1 天前
2026 产业 AI 爆发:JNPF 助企业少走 3 年弯路
人工智能·算法·低代码
贾斯汀玛尔斯1 天前
每天学一个算法--最短路径问题与三类基本算法
算法