LeetCode 55 jump game

问题描述: 55 jump game

这个是我自己参加的一个datawhale的leetcode每日一题的活动,每天22:00前打卡。

最近我在研究动态规划,刚开始看这道跳跃游戏的题目,我打算申请一个dp数组记录每个索引下能够跳跃的最远距离,但是发现这条思路漏掉了一个关键之处,就是每个索引是孤立的。假如当前索引可以跳到末尾,怎么去获取当前索引能否在之前能够可达。

后来想了如下这个方法:用dp记录当前索引能否被跳跃到,dp数组里最后一个元素就是返回值。

具体解题思路:

1.申请一个dp数组,第一个元素肯定是可以到达的,所以记录为true;

2.遍历给定数组,从[当前索引 i + 1,...., i+nums[i] ]这一段都是可以到达的。

3.dp数组里最后一个元素就是返回值。

tip

其一,i+1到 i+nums[i]这一段里可能是超过数组最大长度的。

其二,在遍历当前索引 i 时候,要判断之前0到i-1的时候,能不能到达i这个地方。

所以     if(j<nums.length&&dp[i]==true)

 

这里面有个弊端,就是每个索引都要重新更新,把一小段dp里的元素改成true,其实造成了时间上很大的浪费。

之后参考了一种新的方法,也就是我一开始没走通的思路,之前从起点走到终点不好做,但是从终点跳回起点却很容易做到。

思路:

1.从终点的前一个元素开始,如果当前索引 i +nums[i]>=终点,说明i到终点是OK的

2.不断往前判断,实现一个通路,就是从0开始,经过多段路径到终点,每个路径都是ok的。就可以认为是true.

3.最后判断的依据是前驱能不能到达0这个位置。

这个思路也比较好理解,在时间和空间复杂度上都比我之前的思路要优越的多。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值