成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

leetcode45. Jump Game II

shiguibiao / 2760人閱讀

摘要:轉(zhuǎn)換為廣度優(yōu)先算法即為我們只需要找到每一步的開始節(jié)點和結(jié)束下標,找到下一輪遍歷的最大下標,如果該下標超過了數(shù)組長度,那么結(jié)束遍歷,返回步數(shù),否則將上一輪的最終節(jié)點加一作為起始節(jié)點,并將下一輪最大下標最為結(jié)束節(jié)點,繼續(xù)遍歷。

題目要求
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.

Your goal is to reach the last index in the minimum number of jumps.

For example:
Given array A = [2,3,1,1,4]

The minimum number of jumps to reach the last index is 2. (Jump 1 step from index 0 to 1, then 3 steps to the last index.)

Note:
You can assume that you can always reach the last index.

對于類似體型Jump Game I,請參考這篇博客。
這題相對于I,差別在于已知一定可以到達終點,找到一條最短路徑所需要的步數(shù)。

思路一:遞歸 超時

通過遞歸的方式找到一條到達終點的路徑。通過和當(dāng)前最短路徑比較來省去一些不必要的遍歷。但是存在缺點。其實同一個節(jié)點到達最終節(jié)點的最短步數(shù)是一定的,而每一次遞歸都造成無法省略的重復(fù)遍歷。

    public int jump(int[] nums) {
        jump(nums, 0, 0);
        return minimumSteps;
    }
    
    public void jump(int[] nums, int currentStep, int currentIndex){
        if(currentIndex + nums[currentIndex] >= nums.length){
            minimumSteps = Math.min(minimumSteps, currentStep+1);
            return;
        }
        if(minimumSteps!=0 && currentStep >= minimumSteps){
            return;
        }
        for(int i = 1; i<=nums[currentIndex] ; i++){
            jump(nums, currentStep+1, currentIndex+i);
        }
    }
思路二:反向動態(tài)編程 超時

如果我們從終點往起點尋找,先找可以直接到達終點的最小下標,然后將該下標作為終點,繼續(xù)查找到達該終點的最小下標,并將step加一。這種代碼在大多數(shù)情況下,效率正常,但是如果出現(xiàn)極端情況,比如數(shù)據(jù)量很大,且到達當(dāng)前終點的最小下標即為當(dāng)前終點的前一個節(jié)點。就會造成非常嚴重的無用遍歷。在最好的情況下的時間復(fù)雜度為O(n),但是最差的時間復(fù)雜度為O(n^2)

    public int jump2(int[] nums){
        int minimumSteps = 0;
        int last = nums.length - 1;
        while(last != 0){
            int nextLast = last;
            for(int i =last-1 ; i>=0 ; i--){
                if(nums[i] + i >= last){
                    nextLast = i;
                }
            }
            last = nextLast;
            minimumSteps++;
        }
        
        return minimumSteps;
    }
思路三:BFS 廣度優(yōu)先算法

再回到正序遍歷,舉個例子,輸入的數(shù)組為[2,3,1,1,4],這時候我們知道0步時的下標為0,1步可以走到的下標包括1,2,2步可以走到的下標為3,4,而4即為我們的終點。
轉(zhuǎn)換為廣度優(yōu)先算法即為:

2   step 0
31  step 1
14  step 2

我們只需要找到每一步的開始節(jié)點和結(jié)束下標,找到下一輪遍歷的最大下標,如果該下標超過了數(shù)組長度,那么結(jié)束遍歷,返回步數(shù),否則將上一輪的最終節(jié)點加一作為起始節(jié)點,并將下一輪最大下標最為結(jié)束節(jié)點,繼續(xù)遍歷。

  public int jump3(int[] nums){
        int length = nums.length ; 
        if(length<2) return 0;
        int currentMax = 0, i = 0, nextMax = 0, level = 0;;
        while(currentMax-i+1 > 0){
            level++;
            for( ; i <= currentMax ; i++){
                nextMax = Math.max(nextMax, nums[i]+i);
                if(nextMax>=length-1) return level;
            }
            currentMax = nextMax;
        }
        //說明無法到達終點
        return nextMax>=length-1? level : -1;
    }  


想要了解更多開發(fā)技術(shù),面試教程以及互聯(lián)網(wǎng)公司內(nèi)推,歡迎關(guān)注我的微信公眾號!將會不定期的發(fā)放福利哦~

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/67380.html

相關(guān)文章

  • LeetCode[45] Jump Game II

    摘要:復(fù)雜度思路每次設(shè)置一個窗口,觀察在這一步下能到達的最遠距離,不斷的移動這個窗口。計數(shù),需要移動幾次,才能覆蓋到末尾的值。 LeetCode[45] Jump Game II Given an array of non-negative integers, you are initially positioned at the first index of the array. Eac...

    keelii 評論0 收藏0
  • [LintCode/LeetCode] Jump Game I & II

    摘要:建立動規(guī)數(shù)組,表示從起點處到達該點的可能性。循環(huán)結(jié)束后,數(shù)組對所有點作為終點的可能性都進行了賦值。和的不同在于找到最少的步數(shù)。此時的一定是滿足條件的最小的,所以一定是最優(yōu)解。 Jump Game Problem Given an array of non-negative integers, you are initially positioned at the first index...

    rose 評論0 收藏0
  • [Leetcode] Jump Game 跳躍游戲

    摘要:代碼記錄下當(dāng)前區(qū)域的上界,以便待會更新下一個區(qū)域的上界更新下一個區(qū)域的上界更新下一個區(qū)域的下界后續(xù)如果要求返回最短跳躍路徑,如何實現(xiàn)可以使用,并根據(jù)一個全局最短步數(shù)維護一個全局最短路徑,當(dāng)搜索完所有可能后返回這個全局最短路徑。 Jump Game I 最新解法請見:https://yanjia.me/zh/2019/01/... Given an array of non-negat...

    venmos 評論0 收藏0
  • leetcode55 Jump Game

    摘要:當(dāng)前起點為數(shù)組中下標為零的位置,要走到數(shù)組的最后一個下標。其中,數(shù)組中每一個元素代表當(dāng)前下標下可以前進的最大步數(shù)。如果最終的終點就是起始節(jié)點,那么肯定可以從其實節(jié)點找到一條路徑到達終點,否則失敗。 題目要求 Given an array of non-negative integers, you are initially positioned at the first index o...

    AlanKeene 評論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月下半月匯總(100 題攻略)

    摘要:月下半旬攻略道題,目前已攻略題。目前簡單難度攻略已經(jīng)到題,所以后面會調(diào)整自己,在刷算法與數(shù)據(jù)結(jié)構(gòu)的同時,攻略中等難度的題目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道題,目前已攻略 100 題。 一 目錄 不折騰的前端,和咸魚有什么區(qū)別...

    tain335 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<