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的使用,值得深入理解。

相关推荐
YouEmbedded18 分钟前
解码查找算法与哈希表
数据结构·算法·二分查找·散列表·散列查找·线性查找
greentea_201343 分钟前
Codeforces Round 65 C. Round Table Knights(71)
c语言·开发语言·算法
小秋学嵌入式-不读研版1 小时前
C61-结构体数组
c语言·开发语言·数据结构·笔记·算法
可触的未来,发芽的智生1 小时前
触摸未来2025.10.04:当神经网络拥有了内在记忆……
人工智能·python·神经网络·算法·架构
与己斗其乐无穷1 小时前
刷题记录(11)map和set的简单使用
算法
夜月yeyue2 小时前
个人写HTOS移植shell
c++·mcu·算法·性能优化·架构·mfc
Nix Lockhart2 小时前
《算法与数据结构》第七章[算法3]:图的最小生成树
c语言·数据结构·算法
十重幻想2 小时前
PTA6-5 使用函数求1到10的阶乘和(C)
java·c语言·算法
名誉寒冰2 小时前
【LeetCode】454. 四数相加 II 【分组+哈希表】详解
算法·leetcode·散列表
十重幻想3 小时前
PTA6-4 使用函数统计指定数字的个数(C)
c语言·c++·算法