空间网站大全,国外交易平台,施工企业质量管理制度,怎样判断网站的seo信息好坏❓ 55. 跳跃游戏
难度#xff1a;中等
给你一个非负整数数组 nums #xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标#xff0c;如果可以#xff0c;返回 true #xff1b;否则#xff…❓ 55. 跳跃游戏
难度中等
给你一个非负整数数组 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 所以永远不可能到达最后一个下标。 提示 1 n u m s . l e n g t h 1 0 4 1 nums.length 10^4 1nums.length104 0 n u m s [ i ] 1 0 5 0 nums[i] 10^5 0nums[i]105
思路直接法
如果某一个下标作为 起跳点 的格子可以跳跃的距离是 3那么表示后面 3 个格子都可以作为 起跳点所以可以对每一个能作为 起跳点 的格子都尝试跳一次并把 能跳到最远的位置 flag 不断更新如果可以一直跳到最后就能够到达最后一个下标。
代码(C、Java)
C
class Solution {
public:bool canJump(vectorint nums) {int flag 0; // 能跳到的最远位置for(int i 0; i nums.size(); i){if(i flag) return false;flag max(flag, i nums[i]);}return true;}
};Java
class Solution {public boolean canJump(int[] nums) {int flag 0; // 能跳到的最远位置for(int i 0; i nums.length; i){if(i flag) return false;flag Math.max(flag, i nums[i]);}return true;}
}运行结果 复杂度分析
时间复杂度 O ( n ) O(n) O(n)其中 n 为数组的长度。只需要访问 nums 数组一遍共 n 个位置。空间复杂度 O ( 1 ) O(1) O(1)不需要额外的空间开销。
题目来源力扣。 放弃一件事很容易每天能坚持一件事一定很酷一起每日一题吧 关注我LeetCode主页 / CSDN—力扣专栏每日更新 注 如有不足欢迎指正