Leetcode JAVA刷刷站(55)跳跃游戏

一、题目概述

二、思路方向

在Java中,为了解决这个问题,你可以采用贪心算法的思想。贪心算法在这里的应用主要体现在,每一步都尽可能跳得远,以此来判断是否能够到达数组的最后一个下标。

算法的思路是,遍历数组nums,用一个变量farthest来记录遍历过程中能够到达的最远位置。如果在遍历过程中,farthest的值能够大于等于数组的长度减一(即最后一个下标的索引),那么就可以返回true,表示能够到达最后一个下标。如果在遍历结束时,还没有达到上述条件,则返回false

三、代码实现

java 复制代码
public class Solution {  
    public boolean canJump(int[] nums) {  
        if (nums == null || nums.length == 0) {  
            return false;  
        }  
          
        int farthest = 0; // 能够到达的最远位置  
        for (int i = 0; i < nums.length; i++) {  
            // 如果当前位置已经超过或等于最远位置,那么无法再向前跳了  
            if (i > farthest) {  
                return false;  
            }  
            // 更新能够到达的最远位置  
            farthest = Math.max(farthest, i + nums[i]);  
            // 如果能够到达的最远位置已经包括或超过了最后一个下标,则返回true  
            if (farthest >= nums.length - 1) {  
                return true;  
            }  
        }  
          
        // 如果遍历结束还没有返回true,则默认返回false  
        return false;  
    }  
  
    public static void main(String[] args) {  
        Solution solution = new Solution();  
        int[] nums = {2, 3, 1, 1, 4};  
        System.out.println(solution.canJump(nums)); // 输出 true  
  
        int[] nums2 = {3, 2, 1, 0, 4};  
        System.out.println(solution.canJump(nums2)); // 输出 false  
    }  
}

执行结果:

四、小结

在这段代码中,我们使用了farthest变量来记录遍历过程中能够到达的最远位置。对于数组中的每一个位置,我们都检查是否可以通过当前位置跳跃到更远的位置,并更新farthest的值。如果在遍历过程中发现某个位置i已经超过了当前能够到达的最远位置farthest,那么就无法再向前跳了,直接返回false。如果能够到达的最远位置farthest已经包括或超过了最后一个下标,那么就返回true。如果遍历完整个数组都没有返回true,则默认返回false

结语

自古以来的伟人

大多是抱着不屈不挠的精神

从逆境中挣扎奋斗过来的

!!!

相关推荐
手握风云-17 分钟前
Spring AI:让大模型住进 Spring 生态(三)
java·后端·spring
深邃-1 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
咸鱼2.01 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
We་ct4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9177 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮9 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说9 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
许彰午9 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
wuweijianlove10 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法