网站关键字怎么设置,成都新线加做网站,网站建设东莞长安镇,智慧团建网站什么时候维护好1.题目描述给你一个非负整数数组 nums #xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个下标#xff0c;如果可以#xff0c;返回 true #xff1b;否则#xff0c;返回 false 。示例 1#xff…1.题目描述给你一个非负整数数组 nums 你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个下标如果可以返回 true 否则返回 false 。
示例 1
输入nums [2,3,1,1,4]
输出true
解释可以先跳 1 步从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。示例 2
输入nums [3,2,1,0,4]
输出false
解释无论怎样总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 所以永远不可能到达最后一个下标。
2.解题思路遍历数组更新每此到达的最远距离maxRearch,在循环内部判断当前数组下表是否大于能到达的最远距离maxReach如果大于则说明不能到达目前下标位置所以也不可能到达最后一个下标直接返回 false 而如果当前maxReach大于等于数组最大下标的话说明目前已经可以到达最后一个下标可以直接返回 true.3.代码展示
func canJump(nums []int) bool {maxReach : 0for i : 0; i len(nums); i {if i maxReach {return false}maxReach max(maxReach, i nums[i])if maxReach len(nums) - 1 {return true}}return false
}