leetcode 45. 跳躍游戲 II

[toc]
leetcode 45. 跳躍游戲 II.


題目描述

  1. 跳躍游戲 II

給定一個(gè)長(zhǎng)度為 n 的 0 索引整數(shù)數(shù)組 nums恕沫。初始位置為 nums[0]。

每個(gè)元素 nums[i] 表示從索引 i 向前跳轉(zhuǎn)的最大長(zhǎng)度鲸阔。換句話說迄委,如果你在 nums[i] 處,你可以跳轉(zhuǎn)到任意 nums[i + j] 處:

0 <= j <= nums[i]
i + j < n
返回到達(dá) nums[n - 1] 的最小跳躍次數(shù)叙身。生成的測(cè)試用例可以到達(dá) nums[n - 1]信轿。

示例 1:

輸入: nums = [2,3,1,1,4]
輸出: 2
解釋: 跳到最后一個(gè)位置的最小跳躍數(shù)是 2。
從下標(biāo)為 0 跳到下標(biāo)為 1 的位置财忽,跳 1 步,然后跳 3 步到達(dá)數(shù)組的最后一個(gè)位置紧唱。
示例 2:

輸入: nums = [2,3,0,1,4]
輸出: 2

提示:

1 <= nums.length <= 104
0 <= nums[i] <= 1000
題目保證可以到達(dá) nums[n-1]

解題思路

法1

方法1:模擬跳躍\

要使跳躍的次數(shù)最少那么前后兩次跳躍之間必須默契配合才行

就是說第一次跳躍的位置必須考慮到第二次跳躍,兩次跳躍的可以總距離必須
最遠(yuǎn)才可以,也就是相鄰兩次具有相關(guān)性

我們可以使用動(dòng)態(tài)規(guī)劃的思想來(lái)解決這個(gè)問題

  1. 確定本次可以跳躍的區(qū)間
  2. 跳躍 的位置加上該位置可以跳躍的距離就是兩次跳躍的最遠(yuǎn)距離,最遠(yuǎn)距離最長(zhǎng)的就是本次跳躍的位置,
  3. 每次循環(huán),找出每次可以跳躍的區(qū)間,然后模擬跳到給位置上,在找下一個(gè)跳躍區(qū)間,直到跳完,既然跳躍的次數(shù)
  • 時(shí)間復(fù)雜度(O())
  • 空間復(fù)雜度(O())

執(zhí)行結(jié)果

法1

// 選擇跳躍的位置 返回最遠(yuǎn)兩次跳躍的長(zhǎng)度
func chise(nums []int) (r int) {
    for i := 0; i < len(nums); i++ {
        if r < i+nums[i] {
            r = i + nums[i]
        }
    }
    return
}

func jump(nums []int) (r int) {
    t := 0
    for i, j := 1, nums[0]+1; j < len(nums); r++ {
        t = j
        j = i + chise(nums[i:j]) + 1//從截止位置的后一個(gè)開始記錄區(qū)間(左閉右開的結(jié)構(gòu)特點(diǎn))
        i = t
    }
    r++
    return
}

執(zhí)行結(jié)果:
通過
顯示詳情
查看示例代碼
添加備注

執(zhí)行用時(shí):
8 ms
, 在所有 Go 提交中擊敗了
97.23%
的用戶
內(nèi)存消耗:
5.8 MB
, 在所有 Go 提交中擊敗了
44.27%
的用戶
通過測(cè)試用例:
109 / 109
炫耀一下:

法2


法3


本文由mdnice多平臺(tái)發(fā)布

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蛹锰,一起剝皮案震驚了整個(gè)濱河市绰疤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌峦睡,老刑警劉巖榨了,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件龙屉,死亡現(xiàn)場(chǎng)離奇詭異转捕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)痘儡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門枢步,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)醉途,“玉大人,你說我怎么就攤上這事隘擎。” “怎么了采幌?”我有些...
    開封第一講書人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵休傍,是天一觀的道長(zhǎng)尼夺。 經(jīng)常有香客問我,道長(zhǎng)寝衫,這世上最難降的妖魔是什么拐邪? 我笑而不...
    開封第一講書人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任恤浪,我火速辦了婚禮,結(jié)果婚禮上东臀,老公的妹妹穿的比我還像新娘着饥。我一直安慰自己惰赋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開白布轨奄。 她就那樣靜靜地躺著拒炎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪击你。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評(píng)論 1 307
  • 那天,我揣著相機(jī)與錄音绒障,去河邊找鬼户辱。 笑死,一個(gè)胖子當(dāng)著我的面吹牛庐镐,可吹牛的內(nèi)容都是我干的恩商。 我是一名探鬼主播必逆,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼凰棉!你這毒婦竟也來(lái)了陌粹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蒙幻,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體魏宽,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡队询,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年蚌斩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了范嘱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖受裹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情棉饶,我是刑警寧澤,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布照藻,位于F島的核電站袜啃,受9級(jí)特大地震影響幸缕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宫屠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望告材。 院中可真熱鬧古劲,春花似錦、人聲如沸产艾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)踱阿。三九已至管钳,卻和暖如春软舌,著一層夾襖步出監(jiān)牢的瞬間佛点,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留怀喉,地道東北人船响。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像工猜,于是被迫代替她去往敵國(guó)和親篷帅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拴泌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容