zoukankan      html  css  js  c++  java
  • 55.Jump Game---dp

    题目链接

    题目大意:给一个数组,第i个位置的值表示当前可以往前走的最远距离,求从第一个位置能否顺利走到最后一个位置。例子如下:

    法一(借鉴):DP,dp[i]表示从上一个位置走到当前位置时,剩余的可以往前走的距离。dp公式是:dp[i]=max(dp[i-1],nums[i-1])-1。代码如下(耗时5ms):

     1     public boolean canJump(int[] nums) {
     2         //dp[i]表示从上一个位置走到当前位置i时,还剩余的可往前走的步数是多少
     3         int[] dp = new int[nums.length];
     4         //dp[i] = max(dp[i- 1], nums[i - 1]) - 1
     5         for(int i = 1; i < nums.length; i++) {
     6             dp[i] = Math.max(dp[i - 1], nums[i - 1]) - 1;
     7             if(dp[i] < 0) {
     8                 return false;
     9             }
    10         }
    11         return true;
    12     }
    View Code

    法二(借鉴):贪心,每次都更新记录当前能到达的最远距离,如果最远距离小于当前到达的位置或已到达终点,则break,更新最远距离,i+nums[i]表示当前能到达的最远距离。代码如下(耗时5ms):

     1     public boolean canJump(int[] nums) {
     2         int ma = 0;
     3         for(int i = 0; i < nums.length; i++) {
     4             //如果最远距离小于当前位置,表示当前位置不可达
     5             if(i > ma || ma >= nums.length - 1) {
     6                 break;
     7             }
     8             //更新最远距离
     9             ma = Math.max(ma, i + nums[i]);
    10         }
    11         return ma >= nums.length - 1;
    12     }
    View Code
  • 相关阅读:
    swift init继承问题
    CocoaPods 使用本地代码
    关于Xcode6 Segue 的疑问,没有解决!
    Cocos2d 学习资料推荐
    iOS8中 UILocalNotification 和 UIRemoteNotification 使用注意
    Cocos2d 初学基本知识
    iOS 和 Android 触摸事件传递
    iOS NSOperation的使用
    Android 相机对焦模式
    AES 推荐文章
  • 原文地址:https://www.cnblogs.com/cing/p/9292945.html
Copyright © 2011-2022 走看看