【Golang】LeetCode 55. 跳跃游戏

55. 跳跃游戏

题目描述

思路

我们使用贪心的思路来解决这道题。

想要走的尽可能地远,我们就需要在走到某个可用步数比当前可用步数还要大的位置对可用步数的值进行更新。基于以上思路,我们可以令curr := nums[0],然后从i == 1开始对nums数组进行遍历。

每向后遍历一次,curr -= 1,因为要消耗一次步数才能移动到下一格。同时,如果满足curr <= nums[i],我们应该更新curr = nums[i]。因为当前可用的步数curr至少是和nums[i]相等的,如果nums[i]curr还要大,我们显然应该使用nums[i]作为新的可用步数的值,来让我们走得更远。

最后,在每一次循环开始时,判断curr != 0,如果curr == 0,意味着一定走不到终点了,直接返回false

基于以上思路,我们写代码来解决问题。

Golang 题解

go 复制代码
func canJump(nums []int) bool {
    // 每次跳跃到的位置应该是可用步数最大的位置.
    curr := nums[0]
    for i := 1; i < len(nums); i ++ {
        if curr == 0 {
            return false
        }
        curr -= 1
        if nums[i] >= curr {
            curr = nums[i]
        }
    }
    return true
} 
相关推荐
多米Domi01121 小时前
0x3f第33天复习 (16;45-18:00)
数据结构·python·算法·leetcode·链表
罗湖老棍子21 小时前
【例4-11】最短网络(agrinet)(信息学奥赛一本通- P1350)
算法·图论·kruskal·prim
方圆工作室21 小时前
【C语言图形学】用*号绘制完美圆的三种算法详解与实现【AI】
c语言·开发语言·算法
Lips6111 天前
2026.1.16力扣刷题
数据结构·算法·leetcode
kylezhao20191 天前
C# 文件的输入与输出(I/O)详解
java·算法·c#
CodeByV1 天前
【算法题】堆
算法
kaikaile19951 天前
A星算法避开障碍物寻找最优路径(MATLAB实现)
数据结构·算法·matlab
今天_也很困1 天前
LeetCode 热题100-15.三数之和
数据结构·算法·leetcode
企业对冲系统官1 天前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划
ldccorpora1 天前
GALE Phase 1 Chinese Broadcast News Parallel Text - Part 1数据集介绍,官网编号LDC2007T23
人工智能·深度学习·算法·机器学习·自然语言处理