LeetCode題解:63. 不同路徑 II阶冈,動態(tài)規(guī)劃(空間O(n)),JavaScript塑径,詳細(xì)注釋

原題鏈接:https://leetcode-cn.com/problems/unique-paths-ii/

解題思路:

  1. 在網(wǎng)格中的任意一點(diǎn)女坑,都有向右和向下兩種路徑。同時(shí)它也是從上方和左方兩個(gè)位置走過來的统舀。
  2. 那么匆骗,任意一點(diǎn)的路徑數(shù)量劳景,等于從起點(diǎn)走到上方和左方點(diǎn)的數(shù)量之和。
  3. 第一行和第一列都只有一種路徑碉就,就是從起點(diǎn)一直走到底枢泰。
  4. 我們可以用一個(gè)二維數(shù)組,畫出網(wǎng)格中每個(gè)點(diǎn)的路徑數(shù)量铝噩,一直遞推到終點(diǎn)衡蚂,終點(diǎn)存儲的就是所有的路徑數(shù)量。
  5. 因此動態(tài)規(guī)劃的狀態(tài)轉(zhuǎn)移方程為:dp[i][j]=dp[i-1][j]+dp[i][j-1]骏庸。
  6. 如果遇到障礙物毛甲,則該位置的路徑數(shù)量為0。
  7. 對于起始點(diǎn)obstacleGrid[0][0]具被,如果它沒有障礙物玻募,路徑為1,反之為0一姿。
  8. 由于每個(gè)點(diǎn)的路徑數(shù)量只和它左方和上方有關(guān)七咧,因此狀態(tài)轉(zhuǎn)移方程可以優(yōu)化為:dp[i] = dp[i - 1] + dp[i]
/**
 * @param {number[][]} obstacleGrid
 * @return {number}
 */
var uniquePathsWithObstacles = function(obstacleGrid) {
  // 創(chuàng)建數(shù)組叮叹,存儲最新一行的狀態(tài)
  // 由于新位置的狀態(tài)艾栋,只與它左方和上方的狀態(tài)有關(guān)
  // 也就是dp[j] = dp[j - 1] + dp[j]
  // 因此只需要一維數(shù)組即可
  let dp = new Array(obstacleGrid[0].length).fill(0)
  // 起始位置如果無障礙物,路徑為1蛉顽,否則為0
  dp[0] = obstacleGrid[0][0] ? 0 : 1

  // 遍歷每個(gè)網(wǎng)格位置蝗砾,計(jì)算路徑數(shù)量
  for (let i = 0; i < obstacleGrid.length; i++) {
    for (let j = 0; j < obstacleGrid[0].length; j++) {
      // 如果遇到障礙物,當(dāng)前位置無法經(jīng)過携冤,路徑為0
      if (obstacleGrid[i][j]) {
        dp[j] = 0
      } else {
        // 如果當(dāng)前位置沒有障礙物悼粮,路徑數(shù)量等于左方和上方的數(shù)量之和
        // 如果j為0,dp[j - 1]為undefined曾棕,將其設(shè)置為0扣猫,方便計(jì)算
        dp[j] += dp[j - 1] ?? 0
      }
    }
  }

  // 最后一個(gè)位置存儲的就是最終結(jié)果
  return dp[obstacleGrid[0].length - 1]
};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市翘地,隨后出現(xiàn)的幾起案子申尤,更是在濱河造成了極大的恐慌,老刑警劉巖子眶,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瀑凝,死亡現(xiàn)場離奇詭異序芦,居然都是意外死亡臭杰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進(jìn)店門谚中,熙熙樓的掌柜王于貴愁眉苦臉地迎上來渴杆,“玉大人寥枝,你說我怎么就攤上這事〈沤保” “怎么了囊拜?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長比搭。 經(jīng)常有香客問我冠跷,道長,這世上最難降的妖魔是什么身诺? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任蜜托,我火速辦了婚禮,結(jié)果婚禮上霉赡,老公的妹妹穿的比我還像新娘橄务。我一直安慰自己,他們只是感情好穴亏,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布蜂挪。 她就那樣靜靜地躺著,像睡著了一般嗓化。 火紅的嫁衣襯著肌膚如雪棠涮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天刺覆,我揣著相機(jī)與錄音故爵,去河邊找鬼。 笑死隅津,一個(gè)胖子當(dāng)著我的面吹牛诬垂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播伦仍,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼结窘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了充蓝?” 一聲冷哼從身側(cè)響起隧枫,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎谓苟,沒想到半個(gè)月后官脓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡涝焙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年卑笨,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片仑撞。...
    茶點(diǎn)故事閱讀 38,626評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赤兴,死狀恐怖妖滔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情桶良,我是刑警寧澤座舍,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站陨帆,受9級特大地震影響曲秉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜疲牵,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一岸浑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瑰步,春花似錦矢洲、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至袁滥,卻和暖如春盖桥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背题翻。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工揩徊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人嵌赠。 一個(gè)月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓塑荒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親姜挺。 傳聞我的和親對象是個(gè)殘疾皇子齿税,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評論 2 348

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