45.跳跃游戏

:双层for。复杂度n*n n

java 复制代码
class Solution {
    public int jump(int[] nums) {
        // 找到所有的条约方法,返回其中的最小次数
        // 从后向前,依次记录到最后的次数
        int n = nums.length;
        if(n == 1) return 0;
        // 
        int[] temp = new int[n];
        // temp[n-1] = 0;
        for(int i = n - 2; i >= 0; i--){
            if(i + nums[i] >= n-1){
                temp[i] = 1;
                continue;
            }
            if(nums[i] == 0) {
                // 设置成n,意味着不可达
                temp[i] = n;
                continue;
            }
            int min = Integer.MAX_VALUE;
            for(int j = i+1; j <= Math.min(i+nums[i], n-2); j++){
                min = Math.min(min, temp[j]);
            }
            temp[i] = min+1;
            
        }
        return temp[0];
    }
}

:简化。可以直接在原数组上设置最小长。空间复杂度 1

java 复制代码
public int jump(int[] nums){
    int n = nums.length;
    if(n == 1) return 0;
    for(int i = n - 1; i >= 0; i--){
        if(i == n-1) nums[i] = 0;
        if(i + nums[i] >= n-1){
            nums[i] = 1;
            continue;
        }
        if(nums[i] == 0){
            nums[i] = n;
            continue;
        }
        int min = Integer.MAX_VALUE;
        for(int j = i+1; j <= Math.min(i+nums[i], n-2); j++){
            min = Math.min(min, nums[j]);
        }
        nums[i] = min + 1;
    }
    return nums[0];
}

:复杂度:n 1

java 复制代码
public int jump(int[] nums){
    int range = 0;
    int maxRange = 0;
    int cnt = 0;
    // 注意i的条件,不要遍历最后一个元素
    for(int i = 0; i < nums.length - 1; i++){
        maxRange = Math.max(maxRange, i + nums[i]);
        if(i == range){
            cnt++;
            range = maxRange;
        }
    }
    return cnt;
}
相关推荐
超级码力6668 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑8 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind9 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师9 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F12 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业12 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn12 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室13 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星13 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿14 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算