45. 跳跃游戏 II

给定一个非负整数数组,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

示例:

输入: [2,3,1,1,4]

输出: 2

解释: 跳到最后一个位置的最小跳跃数是 2。

从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。

说明:

假设你总是可以到达数组的最后一个位置。

PS:

鉴于题目已经给了前提,那就是肯定能到达最后一个元素,那么只要考虑每一跳所能达到的最远位置就行了,也就是每次都选择最远可达的点,reach是当前需要进行跳跃的右界限,nextReach是下一次跳跃的右界限,nextReach的值一直动态更新,以保证每次跳跃都是最远的

class Solution {
public int jump(int[] nums) {
if(nums.length == 1) return 0;
int reach = 0;
int nextreach = nums[0];
int step = 0;
for(int i = 0;i<nums.length;i++){
nextreach = Math.max(i+nums[i],nextreach);
if(nextreach >= nums.length-1) return (step+1);
if(i == reach){
step++;
reach = nextreach;
}
}
return step;
}
}

最新文章

  1. C#设计模式之简单工厂模式(Simple Factory)
  2. Unreal4教程总结
  3. 用alarmmanager 多次发送PendingIntent
  4. Redis【知识点】批量删除指定Key
  5. JVM垃圾回收机制总结:调优方法
  6. BZOJ3566 : [SHOI2014]概率充电器
  7. 期望dp BZOJ3450+BZOJ4318
  8. CSS典型案例实践
  9. 兼容古董级IE小结
  10. linux在shell date获取时间的相关操作
  11. 【MySQL】TokuDB引擎初探(MySQL升级为Percona,MySQL升级为MariaDB)
  12. NSArray的排序
  13. SRM 441(1-250pt, 1-500pt)
  14. [Node.js] node-persist: localStorage on the server
  15. Organic Solar Cells - Generations of Solar Cells
  16. 网络协议 19 - RPC协议综述:远在天边近在眼前
  17. isinstance_issubclass
  18. Web API中给领域模型添加媒体类型支持
  19. 干货 | Elasticsearch 集群健康值红色终极解决方案【转】
  20. select()函数 的学习

热门文章

  1. Java语言简介、基础组成、封装、继承、多态、抽象类、内部类、接口
  2. [hdu]5202
  3. IOS App打包发布完整流程
  4. Ubuntu:Tkinter无法导入
  5. CompletableFuture的使用例子
  6. 题解 P2421 【[NOI2002]荒岛野人】
  7. 在IntelliJ IDEA中创建和运行java/scala/spark程序
  8. Win32 Sdk 连接Access数据库
  9. spark机器学习从0到1机器学习工作流 (十一)
  10. 使用基于MVC2模式创建新闻网站