订餐网站开发,织梦怎么做手机网站,用dw做网站用div布局,华星建设集团网站题目描述#xff1a;
给你一个非负整数数组 nums #xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标#xff0c;如果可以#xff0c;返回 true #xff1b;否则#xff0c;返回 false 。 …题目描述
给你一个非负整数数组 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 nums.length 1040 nums[i] 105
通过次数
800.7K
提交次数
1.8M
通过率
43.4%
思路和题解
这个思路和第45题条约游戏||一样的思路都是用滑动窗口的方法。只不过第45题题目保证了能跳到最后要你求出最小的步数。这次我们判断能不能到达末尾我们只需要在每次确定好一个滑动窗口的时候判断这个窗口是否有效即窗口的左端点是不是在右端点的左边或相等。
代码
class Solution {
public:bool canJump(vectorint nums) {int lo0,hi0;while(hinums.size()-1){int right0;for(int ilo;ihi;i){rightmax(nums[i]i,right);}lohi1;hiright;if(lohi) return false;}return true;}
};