码迷,mamicode.com
首页 > 其他好文 > 详细

55. Jump Game

时间:2019-11-03 18:43:54      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:step   array   exp   min   bsp   inpu   开始   ini   integer   

Given an array of non-negative integers, you are initially positioned at the first index of the array.

Each element in the array represents your maximum jump length at that position.

Determine if you are able to reach the last index.

Example 1:

Input: [2,3,1,1,4]
Output: true
Explanation: Jump 1 step from index 0 to 1, then 3 steps to the last index.

Example 2:

Input: [3,2,1,0,4]
Output: false
Explanation: You will always arrive at index 3 no matter what. Its maximum
             jump length is 0, which makes it impossible to reach the last index.



开始以为是dp, 其实不是.
用一个变量reach保存当前能够到达的最远距离索引.每次循环更新该索引即可. 额外需要注意的是循环的i不能超过这个reach. 因为这时无路可走了
class Solution {
public:
    bool canJump(vector<int>& nums) {
        int reach=0;
        for(int i=0;i<=reach&&i<nums.size();++i)
        {
            reach=max(reach,nums[i]+i);
        }
        return reach>=nums.size()-1;
    }
};

 

55. Jump Game

标签:step   array   exp   min   bsp   inpu   开始   ini   integer   

原文地址:https://www.cnblogs.com/lychnis/p/11788061.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!