精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

聊聊DP入門之不同路徑

開發 前端
本文分別給出了深搜,動規,數論三種方法。深搜當然是超時了,順便分析了一下使用深搜的時間復雜度,就可以看出為什么超時了。然后在給出動規的方法,依然是使用動規五部曲,這次我們就要考慮如何正確的初始化了,初始化和遍歷順序其實也很重要!

一個機器人位于一個 m x n 網格的左上角 (起始點在下圖中標記為 “Start” )。

機器人每次只能向下或者向右移動一步。機器人試圖達到網格的右下角(在下圖中標記為 “Finish” )。

問總共有多少條不同的路徑?

示例 1:

  • 輸入:m = 3, n = 7
  • 輸出:28

示例 2:

  • 輸入:m = 2, n = 3
  • 輸出:3

解釋:從左上角開始,總共有 3 條路徑可以到達右下角。

  • 向右 -> 向右 -> 向下
  • 向右 -> 向下 -> 向右
  • 向下 -> 向右 -> 向右

示例 3:

  • 輸入:m = 7, n = 3
  • 輸出:28

示例 4:

  • 輸入:m = 3, n = 3
  • 輸出:6

提示:

  • 1 <= m, n <= 100
  • 題目數據保證答案小于等于 2 * 10^9

思路

深搜

這道題目,剛一看最直觀的想法就是用圖論里的深搜,來枚舉出來有多少種路徑。

注意題目中說機器人每次只能向下或者向右移動一步,那么其實機器人走過的路徑可以抽象為一顆二叉樹,而葉子節點就是終點!

如圖舉例:

不同路徑

此時問題就可以轉化為求二叉樹葉子節點的個數,代碼如下:

  1. class Solution { 
  2. private: 
  3.     int dfs(int i, int j, int m, int n) { 
  4.         if (i > m || j > n) return 0; // 越界了 
  5.         if (i == m && j == n) return 1; // 找到一種方法,相當于找到了葉子節點 
  6.         return dfs(i + 1, j, m, n) + dfs(i, j + 1, m, n); 
  7.     } 
  8. public
  9.     int uniquePaths(int m, int n) { 
  10.         return dfs(1, 1, m, n); 
  11.     } 
  12. }; 

大家如果提交了代碼就會發現超時了!

來分析一下時間復雜度,這個深搜的算法,其實就是要遍歷整個二叉樹。

這顆樹的深度其實就是m+n-1(深度按從1開始計算)。

那二叉樹的節點個數就是 2^(m + n - 1) - 1。可以理解深搜的算法就是遍歷了整個滿二叉樹(其實沒有遍歷整個滿二叉樹,只是近似而已)

所以上面深搜代碼的時間復雜度為,可以看出,這是指數級別的時間復雜度,是非常大的。

動態規劃

機器人從(0 , 0) 位置出發,到(m - 1, n - 1)終點。

按照動規五部曲來分析:

確定dp數組(dp table)以及下標的含義

dp[i][j] :表示從(0 ,0)出發,到(i, j) 有dp[i][j]條不同的路徑。

確定遞推公式

想要求dp[i][j],只能有兩個方向來推導出來,即dp[i - 1][j] 和 dp[i][j - 1]。

此時在回顧一下 dp[i - 1][j] 表示啥,是從(0, 0)的位置到(i - 1, j)有幾條路徑,dp[i][j - 1]同理。

那么很自然,dp[i][j] = dp[i - 1][j] + dp[i][j - 1],因為dp[i][j]只有這兩個方向過來。

dp數組的初始化

如何初始化呢,首先dp[i][0]一定都是1,因為從(0, 0)的位置到(i, 0)的路徑只有一條,那么dp[0][j]也同理。

所以初始化代碼為:

  1. for (int i = 0; i < m; i++) dp[i][0] = 1; 
  2. for (int j = 0; j < n; j++) dp[0][j] = 1; 

確定遍歷順序

這里要看一下遞歸公式dp[i][j] = dp[i - 1][j] + dp[i][j - 1],dp[i][j]都是從其上方和左方推導而來,那么從左到右一層一層遍歷就可以了。

這樣就可以保證推導dp[i][j]的時候,dp[i - 1][j] 和 dp[i][j - 1]一定是有數值的。

舉例推導dp數組

如圖所示:

不同路徑

以上動規五部曲分析完畢,C++代碼如下:

  1. class Solution { 
  2. public
  3.     int uniquePaths(int m, int n) { 
  4.         vector<vector<int>> dp(m, vector<int>(n, 0)); 
  5.         for (int i = 0; i < m; i++) dp[i][0] = 1; 
  6.         for (int j = 0; j < n; j++) dp[0][j] = 1; 
  7.         for (int i = 1; i < m; i++) { 
  8.             for (int j = 1; j < n; j++) { 
  9.                 dp[i][j] = dp[i - 1][j] + dp[i][j - 1]; 
  10.             } 
  11.         } 
  12.         return dp[m - 1][n - 1]; 
  13.     } 
  14. }; 

時間復雜度:

空間復雜度:

其實用一個一維數組(也可以理解是滾動數組)就可以了,但是不利于理解,可以優化點空間,建議先理解了二維,在理解一維,C++代碼如下:

  1. class Solution { 
  2. public
  3.     int uniquePaths(int m, int n) { 
  4.         vector<int> dp(n); 
  5.         for (int i = 0; i < n; i++) dp[i] = 1; 
  6.         for (int j = 1; j < m; j++) { 
  7.             for (int i = 1; i < n; i++) { 
  8.                 dp[i] += dp[i - 1]; 
  9.             } 
  10.         } 
  11.         return dp[n - 1]; 
  12.     } 
  13. }; 

時間復雜度:

空間復雜度:

數論方法

在這個圖中,可以看出一共m,n的話,無論怎么走,走到終點都需要 m + n - 2 步。

不同路徑

在這m + n - 2 步中,一定有 m - 1 步是要向下走的,不用管什么時候向下走。

那么有幾種走法呢?可以轉化為,給你m + n - 2個不同的數,隨便取m - 1個數,有幾種取法。

那么這就是一個組合問題了。

那么答案,如圖所示:

不同路徑

求組合的時候,要防止兩個int相乘溢出! 所以不能把算式的分子都算出來,分母都算出來再做除法。

例如如下代碼是不行的。

  1. class Solution { 
  2. public
  3.     int uniquePaths(int m, int n) { 
  4.         int numerator = 1, denominator = 1; 
  5.         int count = m - 1; 
  6.         int t = m + n - 2; 
  7.         while (count--) numerator *= (t--); // 計算分子,此時分子就會溢出 
  8.         for (int i = 1; i <= m - 1; i++) denominator *= i; // 計算分母 
  9.         return numerator / denominator; 
  10.     } 
  11. }; 

需要在計算分子的時候,不斷除以分母,代碼如下:

  1. class Solution { 
  2. public
  3.     int uniquePaths(int m, int n) { 
  4.         long long numerator = 1; // 分子 
  5.         int denominator = m - 1; // 分母 
  6.         int count = m - 1; 
  7.         int t = m + n - 2; 
  8.         while (count--) { 
  9.             numerator *= (t--); 
  10.             while (denominator != 0 && numerator % denominator == 0) { 
  11.                 numerator /= denominator; 
  12.                 denominator--; 
  13.             } 
  14.         } 
  15.         return numerator; 
  16.     } 
  17. }; 

時間復雜度:

空間復雜度:

計算組合問題的代碼還是有難度的,特別是處理溢出的情況!

總結

本文分別給出了深搜,動規,數論三種方法。

深搜當然是超時了,順便分析了一下使用深搜的時間復雜度,就可以看出為什么超時了。

然后在給出動規的方法,依然是使用動規五部曲,這次我們就要考慮如何正確的初始化了,初始化和遍歷順序其實也很重要!

 

責任編輯:武曉燕 來源: 代碼隨想錄
相關推薦

2022-01-10 11:28:55

數據結構算法DP入門

2021-09-30 11:55:00

微服務

2022-01-11 10:01:25

二叉搜索樹數量

2010-06-10 15:36:23

路由協議的分類

2021-12-28 07:20:44

斐波那契數算法數字

2021-05-07 08:02:53

Sentinel 流量服務

2023-06-05 12:59:03

2021-09-30 09:58:14

路徑總和二叉樹

2021-12-29 11:32:38

數據結構算法爬樓梯

2021-09-01 22:58:22

Canvas標簽

2009-12-31 10:03:58

VPN配置實例

2024-09-04 09:18:03

分區策略

2022-12-28 08:16:16

metric聚合java

2021-07-11 12:12:49

.NETJWTjson

2021-06-08 09:28:12

.Net通知服務

2020-05-27 08:05:33

MybatisMapper接口

2009-12-21 15:04:02

路由器配置

2022-03-02 07:52:13

React類組件函數式組件

2016-11-28 09:00:10

瀏覽器瀏覽器緩存服務端

2021-01-18 10:33:53

Java反射模塊
點贊
收藏

51CTO技術棧公眾號

全部av―极品视觉盛宴亚洲| 北条麻妃在线一区二区免费播放 | 九九精品久久久| 国产在线观看a视频| 国产99久久久久| 欧美视频一区二区三区在线观看| 亚洲韩国在线| 亚洲国产剧情在线观看| 久久精品主播| 欧美乱大交做爰xxxⅹ性3| 国产熟女高潮一区二区三区| 久草综合在线| 欧美日韩亚洲高清| 亚洲第一综合网站| 神马久久精品| 国产在线不卡| 中国人与牲禽动交精品| 欧美夫妇交换xxx| 亚洲精品自拍| 一本到三区不卡视频| 久久久天堂国产精品| 国产综合视频一区二区三区免费| 精品二区久久| 日韩一区二区在线看| 精品国产免费av| 在线三级中文| 中文字幕一区二区三区蜜月| 久久久久久久久久码影片| 久久久国产精品黄毛片| 欧美一级精品| 亚洲美女激情视频| 777久久久精品一区二区三区| 久久久久久国产精品免费无遮挡| 久久久亚洲精品一区二区三区| 欧美性在线观看| 欧美精品久久久久性色| 色偷偷综合网| 国产一区二区三区18| 香港三级日本三级| 7m精品国产导航在线| 宅男噜噜噜66一区二区66| 日韩一级片播放| 欧美第一视频| 国产精品传媒在线| 日韩欧美亚洲v片| 欧美日本网站| 久久香蕉国产线看观看99| 韩国成人动漫在线观看| 性一交一乱一乱一视频| 国产伦精品一区二区三区免费| 国产精品一区二区久久精品 | 欧美高清日韩| 久久精品人人爽| av在线免费播放网址| 天天影视欧美综合在线观看| 欧美日韩一区二区三区视频| 欧美少妇性生活视频| 欧美aa视频| 色就色 综合激情| 亚洲三区在线| 91在线导航| 国产精品家庭影院| 在线码字幕一区| av在线网址观看| 一区二区三区精品在线观看| wwwwww欧美| 成人免费一区二区三区牛牛| 久久免费美女视频| 欧美亚洲爱爱另类综合| www.成人.com| 最近日韩中文字幕| 97精品国产97久久久久久粉红| 日本视频在线| 一区二区三区四区亚洲| 免费特级黄色片| 樱花草涩涩www在线播放| 色婷婷狠狠综合| 中文字幕免费高清在线| 欧美一区在线观看视频| 精品成人在线视频| 99久久激情视频| 欧美系列精品| 精品国产免费一区二区三区香蕉| 国产精品无码电影| 国产日韩视频在线| 亚洲国产成人精品久久| 2一3sex性hd| 成人a'v在线播放| 欧美成人免费大片| 韩国av中文字幕| 蜜桃久久精品一区二区| 成人欧美一区二区三区视频xxx| 日批视频在线播放| 中文字幕欧美日韩一区| 久久青青草综合| 97人人在线| 亚洲午夜久久久久中文字幕久| 男人操女人逼免费视频| 亚洲日本在线观看视频| 欧美一区二区三区精品| 五月婷婷综合在线观看| 91精品亚洲| 欧美中文字幕在线观看| 91好色先生tv| 青草av.久久免费一区| 亚洲中国色老太| 黄色小视频在线观看| 一区二区三区在线观看欧美| 成人在线观看a| 亚洲啊v在线免费视频| 国产亚洲精品美女| 久久9999久久免费精品国产| 蜜桃av一区二区| 麻豆精品传媒视频| 日韩激情美女| 欧美日韩1区2区| 强伦人妻一区二区三区| 亚洲一级特黄| 成人性生交xxxxx网站| 日色在线视频| 性做久久久久久免费观看欧美| 成人av在线播放观看| 国产欧美一区二区三区精品酒店| 91精品国产日韩91久久久久久| 国产精品三级在线观看无码| 欧美~级网站不卡| 国产啪精品视频| 久草在线青青草| 亚洲成人手机在线| 精品国产aⅴ一区二区三区东京热 久久久久99人妻一区二区三区 | 日日摸夜夜添夜夜添国产精品| 国产精品久久久久久久久久久不卡| 粉嫩av一区二区夜夜嗨| 亚洲卡通欧美制服中文| 亚洲欧美aaa| 欧美色女视频| 日韩免费观看网站| 青青草视频在线观看| 亚洲第一精品在线| 无码人妻一区二区三区精品视频| 91精品国产福利在线观看麻豆| 国产精品久久久久99| 色视频免费在线观看| 粉嫩老牛aⅴ一区二区三区| 蜜臀av粉嫩av懂色av| 国产一在线精品一区在线观看| 91福利视频导航| 在线观看h网| 欧美一区永久视频免费观看| 国产一二三四区| 国产一区二区在线观看免费| 国内外成人激情免费视频| 亚洲18在线| 欧美成人午夜激情在线| 国产福利小视频| 一区二区三区精密机械公司| 妖精视频在线观看| 欧美午夜在线| 国产在线精品一区二区三区| 国产理论在线| 精品一区二区三区三区| 国产午夜精品久久久久| 久久精品男人天堂av| 国产一区二区在线免费播放| 欧美高清影院| 中文字幕日韩视频| 一级黄色录像大片| 亚洲精品乱码久久久久久黑人| 日批免费观看视频| 亚洲资源av| 亚洲乱码一区二区三区| 国产日韩在线观看视频| 欧美国产亚洲视频| 日韩福利一区二区| 欧美在线你懂的| 中文字幕三级电影| 国产视频一区免费看| 品久久久久久久久久96高清| av久久网站| 欧美理论电影在线观看| 日本xxxx人| 日本道在线观看一区二区| 成人黄色短视频| 成人美女在线观看| 欧美视频第一区| 91精品国产91久久久久久黑人| 99久久无色码| 成人精品电影在线| 久久国产精品久久久| 天堂在线一二区| 欧美日本国产视频| 日韩精品视频免费看| 中文一区二区在线观看| 亚洲区 欧美区| 噜噜噜久久亚洲精品国产品小说| 夜夜爽www精品| 久久夜色电影| 成人精品久久一区二区三区| 日韩深夜视频| 欧美精品一区二区三区在线| 免费视频久久久| 亚洲一区二区三区四区在线免费观看 | 日本少妇xxxxx| 蜜臀久久久99精品久久久久久| www.欧美黄色| 成人午夜av| 国产欧美日韩一区二区三区| 日日夜夜精品| 日本最新高清不卡中文字幕| 成人爽a毛片免费啪啪动漫 | 丰满大乳少妇在线观看网站| 在线视频日韩精品| 天天干天天爱天天操| 这里只有精品视频在线观看| 国产又粗又猛又黄视频| 亚洲一区二区三区免费视频| 懂色av粉嫩av蜜臀av一区二区三区| 99精品久久只有精品| av地址在线观看| 国内不卡的二区三区中文字幕| av免费网站观看| 一本色道久久| 国产一区二区精品在线| 日本亚洲欧洲无免费码在线| 日本高清不卡在线| 国产偷倩在线播放| 久久国产精品久久久| 日本不卡三区| 在线看日韩av| 国产二区在线播放| 亚洲色图狂野欧美| 日本在线视频1区| 亚洲激情视频在线播放| 亚洲精品一区二区三区不卡| 91精品国产综合久久久久久漫画| 日韩乱码一区二区三区| 日韩欧美aⅴ综合网站发布| 亚洲成人网在线播放| 不卡在线视频中文字幕| 精品人妻人人做人人爽夜夜爽| 久久成人免费网站| 成人黄色一级大片| 国产在线播放一区三区四| 香蕉视频网站入口| 日韩高清一区在线| 天天天干夜夜夜操| 日本亚洲欧美天堂免费| 手机看片福利盒子久久| 老司机久久99久久精品播放免费| 亚洲 高清 成人 动漫| 国产精品毛片| 男女曰b免费视频| 美女在线一区二区| 五月婷婷六月合| 精品一区二区三区在线观看| 91网址在线观看精品| 国产福利一区在线| 欧美丰满熟妇bbb久久久| 成人一级片在线观看| 国产又粗又猛又色| 久久一区二区三区四区| 精品一区二区三区蜜桃在线| 国产精品欧美一级免费| 一起操在线播放| www.亚洲国产| 国产精品无码在线| 国产日韩欧美麻豆| 欧美巨胸大乳hitomi| 亚洲免费在线看| 国产精品99re| 午夜精品久久久久久| 精品久久久久久久久久久久久久久久 | 噜噜噜在线观看免费视频日韩| 欧美 国产 综合| 青青草97国产精品免费观看无弹窗版| 欧美一级xxxx| 成人性生交大片免费看中文网站| 日韩免费高清一区二区| 国产丝袜美腿一区二区三区| 爱爱视频免费在线观看| 午夜激情久久久| 最近中文字幕在线观看| 91精品国产乱码久久蜜臀| 少妇一级淫片免费看| 中文字幕日韩视频| 国产一线二线在线观看| 国产精品久久久91| 警花av一区二区三区| 久久涩涩网站| 亚洲成av人片一区二区密柚| 成人一区二区免费视频| 久久国产麻豆精品| 日本道中文字幕| 国产精品进线69影院| 黄色大片网站在线观看| 在线不卡的av| 国产在线电影| 欧美国产极速在线| 国产综合色在线观看| 成人羞羞视频免费| 第四色成人网| 成人一对一视频| 国产一区二区在线观看视频| 高潮毛片无遮挡| 亚洲激情中文1区| 中文字幕一区二区三区波野结 | 国产中文在线| 久久久免费av| 999色成人| 神马影院午夜我不卡| 婷婷国产精品| 亚洲五码在线观看视频| 裸体一区二区| 手机在线成人av| 亚洲精选视频在线| 中文字幕一区二区三区人妻四季| 亚洲精品成人久久久| 在线视频中文字幕第一页| 国产精品十八以下禁看| 欧美做受69| 91免费黄视频| 福利91精品一区二区三区| 久久久久人妻一区精品色| 色综合久久久久综合体| 熟妇高潮一区二区高潮| 欧美高清视频在线| 国产一区二区三区免费在线| 日韩精品福利视频| 先锋影音久久久| 国产精品久久久免费观看| 亚洲在线观看免费| 国产wwwwwww| 欧美成人午夜激情在线| 精品中文字幕一区二区三区| 国产日本欧美在线| 精品一区二区三区免费视频| 国产精品久久久久久成人| 91成人免费网站| 国产天堂在线| 国产精品爱久久久久久久| 精品一区亚洲| 国产免费一区二区三区视频| 91视频免费观看| 伊人中文字幕在线观看| 亚洲欧美中文日韩在线| videos性欧美另类高清| 欧美日韩一区二区三| 美女尤物久久精品| 亚洲成人黄色av| 欧洲视频一区二区| 日本中文字幕电影在线免费观看| 国产精品视频久久| 国产精品成人av| 亚洲图片 自拍偷拍| 亚洲精品一二三| 亚洲国产视频一区二区三区| 欧美精品电影免费在线观看| 岛国精品一区| 男女av免费观看| 中文字幕不卡在线播放| 一区二区日韩在线观看| 蜜臀久久99精品久久久久久宅男 | 日韩av网站免费在线| 国产午夜精品久久久久久久久| 欧美理论片在线| 1769免费视频在线观看| 高清一区二区三区视频| 最新成人av网站| 午夜剧场高清版免费观看| 成人免费在线视频| 性欧美18一19性猛交| 在线国产精品视频| 亚洲网站免费| 福利在线一区二区| 久久美女艺术照精彩视频福利播放 | 亚洲丝袜制服诱惑| 精品人妻一区二区三区四区不卡 | 国产成人综合网| 日韩久久精品视频| 一区二区av在线| 一区三区自拍| 国产在线观看福利| 国产精品国产三级国产a| 亚洲精品一区二区三区蜜桃| 日韩av免费一区| 自拍欧美日韩| 男人天堂av电影| 日韩一区二区在线免费观看| 亚洲伊人av| 一区二区三区四区在线视频| 成人深夜福利app| 亚洲图片中文字幕| 久久久久久网址| 奇米影视亚洲| 久久人妻少妇嫩草av无码专区| 欧美日韩亚洲高清一区二区| а√在线天堂官网| 中文字幕中文字幕在线中一区高清| 成人福利视频网站| 一级爱爱免费视频|