55.跳跃游戏

题目描述

题目描述

题解(贪心算法)

思路

思路

解析1

解析1

代码

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        // 记录当前能跳到的最远下标
        int farthest = 0;
        
        for (int i = 0; i < nums.length; i++) {
            // 如果当前遍历的下标 i 已经超过了所能到达的最远距离,说明无法继续前进
            if (i > farthest) {
                return false;
            }
            
            // 更新能到达的最远下标
            farthest = Math.max(farthest, i + nums[i]);
            
            // 优化:如果最远距离已经可以到达或越过最后一个下标,直接返回 true
            if (farthest >= nums.length - 1) {
                return true;
            }
        }
        //=========================================
        //问题1:这里return逻辑不会被执行,为什么还要写?
        //=========================================
        return false;
    }
}

问题1:这里return逻辑不会被执行,为什么还要写?

问题1解答

复杂度分析

  • 时间复杂度: O(N)O(N)O(N),其中 NNN 是数组 nums 的长度。我们只需要遍历一遍数组即可得出结果
  • 空间复杂度: O(1)O(1)O(1)。只需要常数级别的额外空间来存储 farthest 变量
相关推荐
手写码匠10 分钟前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力34 分钟前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly42 分钟前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 小时前
SolidWorks草图转三维DWG技巧
算法
tyung1 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
redaijufeng2 小时前
C++雾中风景7:闭包
c++·算法·风景
Chen_harmony2 小时前
一、数据结构概念和复杂度计算
数据结构
小欣加油2 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-3 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新3 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化