LeetCode刷题(python版)——Topic45跳跃游戏 II

一、题设

给你一个非负整数数组 nums ,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

假设你总是可以到达数组的最后一个位置。

示例 1:

输入: nums = [2,3,1,1,4]
输出: 2
解释: 跳到最后一个位置的最小跳跃数是 2。
     从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

示例 2:

输入: nums = [2,3,0,1,4]
输出: 2

二、基本思路

        虽然但是,我也不知道这题为啥是2,毕竟我也没做过1...

        起初我没看清题目是每次最大可以到达 num[i] + i 的下标位置,而是以为要恰好达到,所以觉得这题顺序去做求唯一解就行了...属实有点小呆。

        审清题后发现这题用贪心算法,即要求达到最后用最小的步数,那么就是每次尽量迈大步,所以首先我从当前点开始,计算出最大的步子可以到 nums[i] + i 的位置,那么下一步就可以从当前的 [i+1,nums[i] + i] 的位置去找下一步可以迈出的大步,也可以看作是拓宽范围的过程。如果找到有更大范围的 j ,那么这就是下一步的起点,从 j 的位置再继续扩大范围即可。

        例如nums = [2,3,1,1,4],当 i = 0 时,最大跳一次可以到下标为2的位置,也就是[2,3,1,1,4];下一步从下标 [1,2] 的位置找到下一次最大的范围,也就是j = 1处的3,此时可以跳到 nums[1] + 1 = 4处,这也就是第二次跳跃,此时也到达了某尾,也是最终的结果。

三、代码实现

    def jump(self, nums):
        # step记录步数,currentIndex记录当前下标
        currentIndex,n,step = 0,len(nums),0
        while currentIndex < n - 1:#退出循环即到最后一格
            current_cover = currentIndex + nums[currentIndex]#记录当前最多范围
            if current_cover >= n - 1:#当前一下子就可以跳到最后
                return step + 1
            # 若不可以一下子出,则在生成的最大范围内找更大的范围
            # flag 记录下次的七点
            for nextIndex in range(currentIndex + 1,current_cover + 1):
                if nextIndex + nums[nextIndex] > current_cover:
                    flag = nextIndex
                    current_cover = nextIndex + nums[nextIndex]
            currentIndex = flag# nextIndex即下一次起跳的起点  
            step += 1                    
        return step

四、效率总结

LeetCode刷题(python版)——Topic45跳跃游戏 II_第1张图片

 

你可能感兴趣的:(leetcode,算法,leetcode,算法,数据结构,python)