【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
} 
相关推荐
汀、人工智能4 分钟前
[特殊字符] 第57课:搜索旋转排序数组
数据结构·算法·数据库架构·图论·bfs·搜索旋转排序数组
倦王8 分钟前
力扣日刷47
算法·leetcode·职场和发展
MicroTech202511 分钟前
突破量子数据加载瓶颈,MLGO微算法科技推出面向大规模量子计算的分治态制备技术
科技·算法·量子计算
码王吴彦祖12 分钟前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
SccTsAxR17 分钟前
算法基石:手撕离散化、递归与分治
c++·经验分享·笔记·算法
wuweijianlove18 分钟前
算法测试中的数据规模与时间复杂度匹配的技术4
算法
Q741_14742 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker43 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx1 小时前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
AI成长日志2 小时前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试