力扣刷题Days25-45. 跳跃游戏 II(js)

目录

1,题目

2,代码

贪心算法+正向查找

3,学习

解题思路

具体代码处理

数组遍历的最后边界的处理:


1,题目

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

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

2,代码

贪心算法+正向查找

javascript 复制代码
/**
 * @param {number[]} nums
 * @return {number}
 */
var jump = function(nums) {
    let jumpsTemp = 0;
    let end = 0;
    let maxPosition = 0;

    let steps =  0;
    for(let i = 0;i<nums.length-1;i++){
        maxPosition = Math.max(maxPosition,i+nums[i]);
        if(i === end){
            end = maxPosition;
            steps++;
        }
    }
    return steps;
};
javascript 复制代码
 for(let i = 0;i<nums.length-1;i++){
        maxPosition = Math.max(maxPosition,i+nums[i]);
        if(i === end){
            end = maxPosition;
            steps++;
        }
    }
end和maxPosition变量的值 和数组下标值保持一致,便于数据的使用;

3,学习

解题思路

每次找到可以到达的最远位置,就可以实现线性时间内得到最少的跳跃次数。

具体代码处理

思路中 应该是在每次最远距离中选择下一跳最远的,才进行step++,这里做了转化。

维护当前能够到达的最大下标位置,记作边界。我们从左到右遍历数组,当到达边界的时候,更新边界并将跳跃次数增加。

相比于两层嵌套的循环,在时间上从O(n*n)变为O(n);

数组遍历的最后边界的处理:

我们不用访问最后一个元素,是因为在访问最后一个元素之前,我们的边界一定大于等于最后一个元素,否则无法调到最后一个位置。


勉励自己:贵在坚持!

相关推荐
gumichef3 分钟前
二叉树链式结构的实现
算法·链表·二叉树·队列
战南诚4 分钟前
力扣 之 198.打家劫舍
python·算法·leetcode
AllData公司负责人5 分钟前
亲测丝滑,体验跃迁|AllData通过集成开源项目StreamPark,实时流任务调度更省心!
java·大数据·数据库·人工智能·算法·实时计算·实时开发平台
计算机安禾13 分钟前
【c++面向对象编程】第46篇:CRTP(奇异递归模板模式):静态多态的妙用
开发语言·c++·算法
广州灵眸科技有限公司20 分钟前
瑞芯微(EASY EAI)RV1126B 音频电路
开发语言·人工智能·深度学习·算法·yolo·音视频
GuWenyue25 分钟前
我被 React 性能问题逼疯了,直到学会这 4 个优化技巧
前端
窗边的anini35 分钟前
那个因为 vibecoding 差点搞砸约会的女孩,被 TRAE SOLO 救了
前端·人工智能·程序员
Dlrb121136 分钟前
数据结构-链表
数据结构·链表·逻辑结构·单向链表·物理结构·valgrind工具
用户7138742290036 分钟前
OAuth 2.0 client_id深度解析:从规范到安全实践
前端
李燚39 分钟前
ReAct 循环的 50 行 Go 实现,逐行拆解
javascript·人工智能·react.js·golang·aigc·agent