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;
}
相关推荐
ada7_3 小时前
LeetCode(python)108.将有序数组转换为二叉搜索树
数据结构·python·算法·leetcode
独自破碎E4 小时前
加油站环路问题
java·开发语言·算法·leetcode
Swift社区4 小时前
LeetCode 445 - 两数相加 II
算法·leetcode·职场和发展
墨染点香4 小时前
LeetCode 刷题【187. 重复的DNA序列】
算法·leetcode·职场和发展
路弥行至4 小时前
FreeRTOS任务管理详解中: FreeRTOS任务创建与删除实战教程(动态方法)
c语言·开发语言·笔记·stm32·操作系统·freertos·入门教程
了一梨5 小时前
外设与接口:input子系统
linux·c语言
2401_841495645 小时前
【LeetCode刷题】最大子数组和
数据结构·python·算法·leetcode·动态规划·最大值·最大子数组和
我是华为OD~HR~栗栗呀5 小时前
23届(华为od)-C开发面经
java·c语言·c++·python·华为od·华为·面试
liu****6 小时前
8.栈和队列
c语言·开发语言·数据结构·c++·算法