LeetCode刷题笔记:55.跳跃游戏

1. 问题描述

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

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

判断你是否能够到达最后一个下标。

2. 解题思路

维护一个变量 k,用来记录前 n - 1 个元素能跳到的最远距离。

3. 代码实现

class Solution {
    
    
    public boolean canJump(int[] nums) {
    
    
        if (nums == null) {
    
    
            return false;
        }
        //前n-1个元素能够跳到的最远距离
        int k = 0;
        for (int i = 0; i <= k; i++) {
    
    
            //第i个元素能够跳到的最远距离
            int temp = i + nums[i];
            //更新最远距离
            k = Math.max(k, temp);
            //如果最远距离已经大于或等于最后一个元素的下标,则说明能跳过去,退出. 减少循环
            if (k >= nums.length - 1) {
    
    
                return true;
            }
        }
        //最远距离k不再改变,且没有到末尾元素
        return false;
    }
}

猜你喜欢

转载自blog.csdn.net/hutianle/article/details/126483322