力扣-45.跳跃游戏 ll

题目描述

给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。

每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处:

0 <= j <= nums[i]

i + j < n

返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。

java 复制代码
class Solution {
    public int jump(int[] nums) {
        int[] dp = new int[nums.length];
        Arrays.fill(dp,10001);
        dp[0] = 0;
        for(int i = 0; i < nums.length; i++){
            for(int j = 1; j <= nums[i] && i+j <nums.length; j++){
                dp[i+j] = Math.min(dp[i+j], dp[i] + 1);
            }
        }
        return dp[nums.length-1];
    }
}

小结:动规很容易想到,dp数组的含义是到达nums[i]最小步数,但这道题应该是贪心算法的题,贪心的解法二刷的时候再看吧。

相关推荐
NAGNIP6 小时前
一文搞懂树模型与集成模型
算法·面试
NAGNIP6 小时前
万字长文!一文搞懂监督学习中的分类模型!
算法·面试
技术狂人1686 小时前
工业大模型工程化部署实战!4 卡 L40S 高可用集群(动态资源调度 + 监控告警 + 国产化适配)
人工智能·算法·面试·职场和发展·vllm
D_FW6 小时前
数据结构第六章:图
数据结构·算法
a程序小傲7 小时前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
自学不成才7 小时前
深度复盘:一次flutter应用基于内存取证的黑盒加密破解实录并完善算法推理助手
c++·python·算法·数据挖掘
June`8 小时前
全排列与子集算法精解
算法·leetcode·深度优先
徐先生 @_@|||8 小时前
Palantir Foundry 五层架构模型详解
开发语言·python·深度学习·算法·机器学习·架构
夏鹏今天学习了吗9 小时前
【LeetCode热题100(78/100)】爬楼梯
算法·leetcode·职场和发展