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;
}
相关推荐
元亓亓亓13 小时前
LeetCode热题100--79. 单词搜索
算法·leetcode·职场和发展
hazy1k13 小时前
ESP32基础-Socket通信 (TCP/UDP)
c语言·单片机·嵌入式硬件·网络协议·tcp/ip·udp·esp32
dvvvvvw13 小时前
x的y次幂的递归函数.c
c语言
2501_9411437314 小时前
缓存中间件Redis与Memcached在高并发互联网系统优化与实践经验分享
leetcode
Elias不吃糖16 小时前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
Want59516 小时前
C/C++跳动的爱心②
c语言·开发语言·c++
大牙Adela16 小时前
在Mac上通过Multipass虚拟机中的Ubuntu系统使用Graphviz工具
c语言·qt·ubuntu·macos·multipass·graphviz
无限进步_17 小时前
C语言动态内存管理:掌握malloc、calloc、realloc和free的实战应用
c语言·开发语言·c++·git·算法·github·visual studio
EXtreme3517 小时前
【C 语言硬核避坑】动态内存管理:从野指针到柔性数组的“防爆”指南
c语言·动态内存管理·内存泄漏
野蛮人6号18 小时前
力扣热题100道前62道,内容和力扣官方稍有不同,记录了本人的一些独特的解法
数据结构·算法·leetcode