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;
}
相关推荐
Tomhex6 小时前
C语言内存安全防护指南
c语言
230万光年的思念8 小时前
zerotier连不上的问题
c语言
XiYang-DING11 小时前
【LeetCode】Hash | 136.只出现一次的数字
算法·leetcode·哈希算法
Fanfanaas11 小时前
Linux 基础开发工具(二)
linux·运维·服务器·c语言
leaves falling12 小时前
C/C++ const:修饰变量和指针的区别(和引用底层关系)
c语言·开发语言·c++
网域小星球12 小时前
C 语言从 0 入门(十二)|指针与数组:数组名本质、指针遍历数组
c语言·算法·指针·数组·指针遍历数组
Tairitsu_H12 小时前
C语言:排序(一)
c语言·数据结构·排序
12.=0.13 小时前
【stm32_5】Systick嘀嗒定时器、解析时钟源、分析时钟树、应用Systick设计延时
c语言·stm32·单片机·嵌入式硬件
嘻嘻哈哈樱桃13 小时前
俄罗斯套娃信封问题力扣--354
算法·leetcode·职场和发展
田梓燊13 小时前
2026/4/12 leetcode 1320
算法·leetcode·职场和发展