首页 > 其他 > 详细

leetcode_Jump Game

时间:2017-05-24 20:48:05      阅读:273      评论:0      收藏:0      [点我收藏+]

描写叙述:

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.
For example:
A = [2,3,1,1,4], return true.
A = [3,2,1,0,4], return false.

思路:

和求Max Subarray类似,维护一个当前元素能够跳至的最大值,每循环一次更新reach=Math.max(nums[i]+1,reach),当i>reach或i>=nums.length的时候循环终止,最后看循环是否到达了最后。到达最后则返回true,否则,返回false.

代码:

public boolean canJump(int[] nums) {
        int i=0;
        for(int reach=0;i<nums.length&&i<=reach;i++)
        {
        	reach=Math.max(nums[i]+i,reach);
        }
        return i==nums.length;
    }

leetcode_Jump Game

原文:http://www.cnblogs.com/liguangsunls/p/6900816.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!