C语言 | Leetcode C语言题解之第55题跳跃游戏

题目:

题解:

cpp 复制代码
#define max(a, b) (((a) > (b)) ? (a) : (b))

bool canJump(int* nums, int numsSize){
    int cover = 0;

    int i;
    // 只可能获取cover范围中的步数,所以i<=cover
    for(i = 0; i <= cover; ++i) {
        // 更新cover为从i出发能到达的最大值/cover的值中较大值
        cover = max(i + nums[i], cover);

        // 若更新后cover可以到达最后的元素,返回true
        if(cover >= numsSize - 1)
            return true;
    }

    return false;
}
相关推荐
sin_hielo14 分钟前
leetcode 2654
算法·leetcode
..过云雨20 分钟前
13.【Linux系统编程】从ELF格式深入理解动静态库
linux·c语言·c++·后端
学学学无无止境23 分钟前
力扣-路径总和
leetcode
flashlight_hi34 分钟前
LeetCode 分类刷题:1669. 合并两个链表
javascript·leetcode·链表
智者知已应修善业1 小时前
【给定英文字符串统计最多小写最前输出】2023-2-27
c语言·开发语言·c++·经验分享·笔记·算法
无限进步_3 小时前
C语言atoi函数实现详解:从基础到优化
c语言·开发语言·c++·git·后端·github·visual studio
小欣加油3 小时前
leetcode 1513 仅含1的子串数
c++·算法·leetcode·职场和发展
树在风中摇曳3 小时前
【C语言预处理器全解析】宏、条件编译、字符串化、拼接
c语言·算法
fashion 道格4 小时前
用 C 语言破解汉诺塔难题:递归思想的实战演练
c语言·算法
yuuki2332335 小时前
【数据结构】常见时间复杂度以及空间复杂度
c语言·数据结构·后端·算法