zoukankan      html  css  js  c++  java
  • 【每日一题-leetcode】45.跳跃游戏 ||

    45.跳跃游戏 ||

    1. 跳跃游戏 II

    难度困难547

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

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

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

    示例:

    输入: [2,3,1,1,4]
    输出: 2
    解释: 跳到最后一个位置的最小跳跃数是 2。
         从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。
    

    从后往前查找-贪心

       /**反向查找出发位置
              跳跃游戏 可以通过贪心算法来完成,可以从前往后 或者 从后往前,通过获取局部最优解
              来解决全局最优解。
              从nums.length-1位置 查找之前的一个元素是否能到达,如果可以,遍历数组 从0开始到这个位置。
              找出最大值,依序查找,每次选取最大的步数,也就是局部最优解,而最优解,就可以决定全局是一个最优解
              time : O(N^2) 当数组中都是相同的数字,需要查找N^2次
              space : O(1)
              break 跳出循环  continue 结束本次循环 继续下次循环
            */
            public int jump(int[] nums) {
              if(nums == null || nums.length == 0){
                  return -1;
              }
              int steps = 0;//需要跳跃的次数
              int position = nums.length-1;
              while(position > 0){
                for(int i=0;i<position;i++){
                  if(nums[i]+i>=position){//可以到达
                    position = i;
                    steps++;
                    break;
                  }
                }
              }
              return steps;
            }
    

    从前往后查找-贪心

    /*
            刚才从后往前推 对于特定的相同的数组,需要遍历O(N^2)次 时间复杂度比较高。
            我们换一个思路 从前往后推。[2,3,1,1,4]
            steps>记录次数  end>记录当前步长可以走的界限。
            比如 从0 位置出发,end = 2 在0位置2步内找到最大值。最大为3,调到3上
            在end=3位置查找最大值 发现可以跳出。因此结束。
            ps:此处 我们没有跳跃到数组的末尾位置,因此当可以跳出的时候只会大于或等于。
            time : O(n) space :O(1)
        */
        public int jump(int[] nums) {
            if(nums == null || nums.length == 0){
                return -1;
            }
            int steps = 0;
            int end = 0;//当前可以跳跃的最大步长
            int maxLength = 0;
            for(int i= 0;i<nums.length-1;i++){
                maxLength = Math.max(maxLength,nums[i]+i);
                if(end == i){ //end == i 其实比较的就是在最大步长内 是否会有一个更大的步长 
                    end = maxLength;
                    steps++;
                }
            }
            return steps;
        }
    
  • 相关阅读:
    @PathVariable和@RequestParam的区别,@SessionAttributes
    forward和redirect的区别
    JSP页面的静态包含和动态包含
    ConcurrentHashMap源码解析
    Jdk1.6 JUC源码解析(1)-atomic-AtomicXXX
    最小生成树
    tomcat启动项目内存溢出问题
    强引用,弱引用,4种Java引用浅解(涉及jvm垃圾回收)
    CXF 在WAS上报Unmarshalling Error的问题
    CXF处理Date类型的俩种方式
  • 原文地址:https://www.cnblogs.com/qxlxi/p/12860582.html
Copyright © 2011-2022 走看看