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;
}
相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
澈2074 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
ambition202425 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_5 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi5 小时前
前缀和差分
算法·图论
代码旅人ing5 小时前
链表算法刷题指南
数据结构·算法·链表
Yungoal5 小时前
常见 时间复杂度计算
c++·算法
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
不爱吃炸鸡柳6 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK6 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法