LeetCode第45题跳跃游戏 II

继续打卡算法题,今天学习的是LeetCode第45题跳跃游戏 II,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

先说说暴力解法,把每个位置到最终位置的跳跃次数全部记录下来,结果排序之和取最小的,这样想想比较简单,但是这样写代码复杂度增高了,需要两层循环,相当于时间复杂度O(m*n)。

有没有一层循环的办法呢?有的,我们循环每个数组元素,如果当前跳跃的大小比之前的位置小,就不跳跃,大于等于的情况才跳跃。

本题解题技巧

1、使用一层循环,不是每次都跳跃,而是等跳跃的位置比之前的都大的时候才跳跃

编码解决

java 复制代码
class Solution {
    public int jump(int[] nums) {
        int length = nums.length;
        int end = 0;
        int maxPosition = 0; 
        int steps = 0;
        for (int i = 0; i < length - 1; i++) {
            maxPosition = Math.max(maxPosition, i + nums[i]);
            //每次跳跃,选最大能跳跃的一个, 已经到上次跳跃后的最大位置,这个时候需要跳跃了
            if (i == end) {
                end = maxPosition;
                steps++;
            }
        }
        return steps;
    }
}

总结

这个跳跃游戏使用暴力解法比较麻烦,通过一层循环,不断的找最大可以跳跃的地方,达到了上次最大跳跃的地方再跳跃一次。

相关推荐
进击的小白菜9 分钟前
用Java实现单词搜索(LeetCode 79)——回溯算法详解
java·算法·leetcode
珂朵莉MM28 分钟前
2024 睿抗机器人开发者大赛CAIP-编程技能赛-专科组(国赛)解题报告 | 珂学家
开发语言·人工智能·算法·leetcode·职场和发展·深度优先·图论
编程乐学(Arfan开发工程师)35 分钟前
06、基础入门-SpringBoot-依赖管理特性
android·spring boot·后端
编程乐学(Arfan开发工程师)36 分钟前
05、基础入门-SpringBoot-HelloWorld
java·spring boot·后端
小智学长 | 嵌入式37 分钟前
进阶-数据结构部分:2、常用排序算法
java·数据结构·算法
少了一只鹅37 分钟前
字符函数和字符串函数
c语言·算法
橘子海全栈攻城狮1 小时前
【源码+文档+调试讲解】党员之家服务系统小程序1
java·开发语言·spring boot·后端·小程序·旅游
冼紫菜1 小时前
Java开发中使用 RabbitMQ 入门到进阶详解(含注解方式、JSON配置)
java·spring boot·后端·rabbitmq·springcloud
boring_1112 小时前
Apache Pulsar 消息、流、存储的融合
分布式·后端
Dr.9272 小时前
1-10 目录树
java·数据结构·算法