LeetCode第55题 - 跳跃游戏

题目

解答一

java 复制代码
class Solution {   
    public boolean canJump(int[] nums) {
        if (nums == null || nums.length == 0) {
            return false;
        }
        if (nums[0] == 0 && nums.length == 1) {
            return true;
        }
        return canJump(nums, 0);
    }

    public boolean canJump(int[] nums, int index) {
        if (index > nums.length - 1) {
            return false;
        }
        if (nums[index] == 0) {
            return false;
        }

        if (nums[index] + index >= nums.length - 1) {
            return true;
        }

        // for (int i = 1; i <= nums[index]; ++i) {
        for (int i = nums[index]; i > 0; --i) {
            if (canJump(nums, index + i)) {
                return true;
            }
        }

        return false;
    }
}

解答二

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int max = 0;
        for (int i = 0; i < nums.length && i <= max; i++) {
            max = Math.max(max, i + nums[i]);
            if (max >= nums.length - 1) {
                return true;
            }
        }

        return false;
    }
}

总结

解答一使用递归,可以解决问题,但当输入规模增大时,可能出现递归过多、栈溢出的现象,同时效率也不满足要求。

解决二使用贪心算法,简单、直接、暴力、有效。变量max的使用,值得深入理解。

相关推荐
空山新雨后、2 分钟前
从 CIFAR 到 ImageNet:计算机视觉基准背后的方法论
人工智能·深度学习·算法·计算机视觉
YuTaoShao11 分钟前
【LeetCode 每日一题】712. 两个字符串的最小ASCII删除和——(解法三)状态压缩
算法·leetcode·职场和发展
liliangcsdn15 分钟前
LLM训练中batchsize与过拟合和泛化的关系
人工智能·算法·机器学习
muddjsv19 分钟前
什么是算法?——现代视角下的一次凝视
算法
laplace012319 分钟前
智能体经典范式构建
算法·langchain·大模型·agent
小雨下雨的雨21 分钟前
Flutter鸿蒙共赢——色彩的流变:流体梯度网格与现代视觉重构
算法·flutter·华为·重构·交互·harmonyos·鸿蒙
Swift社区22 分钟前
LeetCode 473 火柴拼正方形 - Swift 题解
算法·leetcode·swift
Allen_LVyingbo22 分钟前
面向“病历生成 + CDI/ICD”多智能体系统的选型策略与落地实践(三)
算法·自然语言处理·性能优化·知识图谱·健康医疗·柔性数组
金枪不摆鳍23 分钟前
算法-链表双指针
数据结构·算法·链表
MarkHD25 分钟前
智能体在车联网中的应用:第53天 基于CTDE-MAPPO的快速路合流区协同驾驶项目蓝图(SUMO路网与智能体设计篇)
算法