精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

精品高清视频| 欧美一区在线直播| 亚洲欧美综合视频| 91高清视频在线观看| 久久久91精品国产一区二区三区| 国产精品久久99久久| 一级黄色录像视频| 久久不见久久见国语| 3751色影院一区二区三区| 成年人网站国产| aaa在线免费观看| 成人久久18免费网站麻豆| 国产精品久久久久久久9999 | 肥臀熟女一区二区三区| 视频精品一区二区| 久久久欧美一区二区| 国产破处视频在线观看| 精品国产乱子伦一区二区| 欧美天天综合网| 国产精品网站免费| caoporn免费在线| 国产亚洲一区二区三区| 国产亚洲精品美女久久久m| 在线观看免费中文字幕| 国产亚洲精品v| 欧美日韩ab片| 激情无码人妻又粗又大| 国产永久精品大片wwwapp| 欧美tickling挠脚心丨vk| 制服丝袜中文字幕第一页 | 欧美成人嫩草网站| 最好看的2019年中文视频| 成人网站免费观看| 国产精品1luya在线播放| 欧美一区二区三区白人| www.亚洲高清| 黄色精品视频| 91福利视频网站| 男人日女人bb视频| heyzo一区| 亚洲综合自拍偷拍| 操bbb操bbb| 精品视频在线一区二区| 中文成人综合网| 亚洲精品乱码视频| 国产三级电影在线观看| 久久久99精品久久| 欧美日韩在线观看一区| 黄色在线网站| 久久九九久久九九| 日韩精品不卡| 成人福利在线| 中文字幕免费不卡| 亚洲国产一区二区精品视频| 成人免费一区二区三区视频网站| 久久美女艺术照精彩视频福利播放| 好吊色欧美一区二区三区视频| 高清一区二区三区四区| 成人18视频在线播放| 国产欧美一区二区在线播放| 噜噜噜久久,亚洲精品国产品| 国产成人精品亚洲午夜麻豆| 岛国视频一区免费观看| 国产香蕉在线观看| 91亚洲精华国产精华精华液| 欧美精品一区二区三区久久| 国产小视频在线观看| 国产精品全国免费观看高清| 在线视频福利一区| 99在线视频观看| 亚洲h动漫在线| 美女福利视频在线| 国产资源一区| 日韩天堂在线观看| 人妻换人妻a片爽麻豆| 日韩电影不卡一区| 中文字幕av日韩| 欧美国产日韩综合| 国产亚洲在线| 国产精品视频xxxx| 精品人妻一区二区三区四区不卡 | 欧美精品一卡两卡| aaaaa黄色片| 偷拍视屏一区| 最近中文字幕日韩精品| 欧美日韩综合一区二区| 国产欧美在线| 91九色综合久久| 午夜性色福利影院| 国产精品久久二区二区| 97在线国产视频| 成人在线网站| 精品国产污网站| 日本人亚洲人jjzzjjz| 你懂的国产精品永久在线| 国产91精品久久久| ,亚洲人成毛片在线播放| 成人av在线网站| 亚洲成人18| segui88久久综合| 欧美天堂亚洲电影院在线播放| 免费看91视频| 欧美亚洲国产激情| 97精品久久久中文字幕免费| 亚洲一级av毛片| 99久久精品情趣| 国产精品99久久久久久大便| 国产高清不卡| 欧美成人video| 日韩精品电影一区二区三区| 精品成人一区| 91精品视频在线播放| 欧美偷拍视频| 亚洲午夜视频在线观看| 爱爱爱爱免费视频| 国产欧美日韩精品一区二区免费| 欧美日韩福利视频| 亚洲最新av网站| 26uuu亚洲综合色欧美 | 日韩中文字幕区一区有砖一区| 97超碰人人看人人| 日本高清中文字幕在线| 欧美性生交xxxxx久久久| 精品无码av一区二区三区| 久久精品国产大片免费观看| 97久久久久久| 午夜老司机福利| 亚洲视频一区在线观看| 久久精品网站视频| 亚洲v天堂v手机在线| 欧美激情手机在线视频| av观看在线免费| 欧美高清在线精品一区| 日本在线观看a| 欧美理论电影在线精品| 欧美激情综合亚洲一二区| japanese国产| 亚洲精品免费看| 亚洲图片 自拍偷拍| 欧美aaaa视频| 成人国产亚洲精品a区天堂华泰| 国产中文字幕在线看| 色综合久久88色综合天天| 少妇一级淫片免费放播放| 欧美私人啪啪vps| 亚洲一区二区中文字幕| 91三级在线| 日韩免费视频一区二区| 亚洲国产精品免费在线观看| 国产毛片精品一区| 日韩视频 中文字幕| 看亚洲a级一级毛片| 欧美另类99xxxxx| 亚洲av无码一区二区三区性色| 亚洲精品亚洲人成人网在线播放| 欧美日韩综合色| 成人网在线免费观看| 日本在线www| 欧美美女bb生活片| 爱爱视频免费在线观看| 国产在线一区二区| 99久久99久久精品| 国产精品极品国产中出| 国内精品久久久久影院优| 欧美综合视频在线| 欧美性色视频在线| 国产破处视频在线观看| 激情久久五月天| 4444亚洲人成无码网在线观看| 精品国产欧美| 久久久噜噜噜久久中文字免| 同心难改在线观看| 欧美图区在线视频| 欧美成人精品欧美一级私黄| 成人爱爱电影网址| 99视频精品免费| 91精品啪在线观看国产18| 成人欧美一区二区三区视频xxx| rebdb初裸写真在线观看| 日韩福利视频在线观看| 在线免费一区二区| 亚洲精品日韩一| 在线免费观看污视频| 石原莉奈一区二区三区在线观看| 中文字幕欧美日韩一区二区三区| 91在线一区| 国产不卡精品视男人的天堂| 黄色网页在线免费看| 精品少妇一区二区| 夜夜爽妓女8888视频免费观看| 亚洲欧美在线aaa| 日本一区二区在线免费观看| 美女视频黄免费的久久| 人人妻人人澡人人爽欧美一区 | 日本视频免费一区| 看一级黄色录像| 免费视频国产一区| 99re在线观看| 日韩一级二级| 国模叶桐国产精品一区| 亚洲xxxxxx| 亚洲高清福利视频| 一卡二卡在线视频| 精品日韩中文字幕| 污软件在线观看| 久久久www成人免费毛片麻豆| 佐山爱在线视频| 石原莉奈一区二区三区在线观看 | heyzo在线播放| 日韩中文字幕视频在线观看| 天堂中文网在线| 欧美一级一区二区| 男人天堂视频在线| 午夜久久久影院| 99热在线观看精品| 久久久综合激的五月天| 久久发布国产伦子伦精品| 日韩成人精品在线观看| 国产在线精品91| 欧美日韩国产精品一区二区亚洲| 一本色道久久综合亚洲精品婷婷 | 国产又爽又黄又嫩又猛又粗| 一本一道综合狠狠老| 日韩欧美a级片| 日韩美女视频一区二区| 成年人在线免费看片| 91色在线porny| 一区二区三区四区影院| 国产一区二区不卡| 亚洲免费成人在线视频| 日韩av中文字幕一区二区三区| 色综合久久久久无码专区| 亚洲天堂黄色| 欧美人与动牲交xxxxbbbb| 天天天综合网| 亚洲一区二区三区精品在线观看 | ww国产内射精品后入国产| 午夜精品av| 久久av喷吹av高潮av| 五月婷婷六月综合| 中文一区一区三区免费| 欧美激情理论| 夜夜爽99久久国产综合精品女不卡| 成人在线丰满少妇av| 日本在线观看一区| 国产一区日韩| 日日噜噜噜噜夜夜爽亚洲精品| 国产欧美日韩在线一区二区| 欧美极品一区二区| 精品久久影院| 亚洲精美视频| 日韩系列欧美系列| 久久免费视频2| 一区二区电影| 久久这里只有精品8| 红桃视频欧美| 国产91在线视频观看| 免费亚洲一区| 欧美精品无码一区二区三区| 美女一区二区三区在线观看| 亚洲 激情 在线| 国产在线播精品第三| 黄页网站在线看| 99久久久精品免费观看国产蜜| 欧美 日本 国产| 中文字幕高清一区| 日韩国产第一页| 亚洲一区二区视频在线观看| 日本三级欧美三级| 色天天综合久久久久综合片| 中文av免费观看| 欧美一二三区精品| 无码精品人妻一区二区三区影院 | 中文字幕资源网在线观看| 久久99国产精品自在自在app| 超碰资源在线| 国产精品久久久久久久久免费看| 999久久久国产999久久久| 成人3d动漫一区二区三区91| 同性恋视频一区| 一区二区三区欧美在线| 国产精品a级| 黄色a级片免费| 极品少妇xxxx精品少妇偷拍 | 美女av一区| 午夜精品亚洲一区二区三区嫩草| 欧美一区二区| 欧美 国产 小说 另类| 精品一区二区三区在线视频| 男人的天堂影院| 中文字幕免费不卡在线| 国产一级生活片| 欧美偷拍一区二区| 免费成人在线看| 中文字幕9999| 美女av在线免费看| 91亚洲永久免费精品| 欧美日韩看看2015永久免费| 在线免费观看成人网| 国产一区二区你懂的| www.五月天色| 久久精品人人做| 国产亚洲精品女人久久久久久| 欧美性猛片aaaaaaa做受| 蜜桃视频久久一区免费观看入口 | 日韩在线一卡二卡| 欧美丝袜一区二区| 国产熟女一区二区丰满| 亚洲欧洲一区二区三区久久| 三级福利片在线观看| 国产精品成人免费电影| 欧美日韩导航| 欧美大黑帍在线播放| 久久精品国产免费| 三级网站在线免费观看| 一区二区三区在线视频免费| 精品久久久久久久久久久久久久久久| 日韩亚洲欧美高清| 日韩在线免费电影| 国产成人涩涩涩视频在线观看 | 国产一区二区三区四| 国产精品毛片一区二区| 亚洲成人精品一区| 精品欧美一区二区精品少妇| 最新国产成人av网站网址麻豆| 成人欧美大片| 国产一区福利视频| 欧美激情亚洲| 日批视频在线看| 中文字幕一区视频| 中文字幕在线观看免费| 亚洲人成电影网站色xx| 日韩欧美精品一区二区三区| 成人免费观看网站| 欧美日韩理论| 久久久久中文字幕亚洲精品| 中文字幕亚洲区| 中文字幕视频二区| 国产亚洲精品久久久久久777| 成人香蕉视频| 免费看成人片| 麻豆精品网站| 精品欧美一区二区久久久| 日韩欧美国产视频| 四虎在线观看| 欧美在线视频一二三| 亚洲人成网www| 国产成人久久777777| 国产午夜精品久久| 91porny九色| 中文字幕综合在线| 日韩第二十一页| 欧美 另类 交| 国产成人精品免费在线| 国产网友自拍视频| 精品在线观看国产| 亚洲成av在线| 一道精品一区二区三区| 韩国成人在线视频| 免费又黄又爽又色的视频| 亚洲а∨天堂久久精品9966| 91超碰在线| 欧美午夜欧美| 久久精品99久久久| 精品97人妻无码中文永久在线| 精品国产一区二区精华| 色资源二区在线视频| 日本亚洲导航| 国产一区二区视频在线| 国产一级淫片免费| 亚洲欧洲中文天堂| 视频欧美精品| 日本福利视频一区| 久久久久久久久久久久久夜| 一区二区视频网| 九九热精品视频国产| 婷婷激情久久| 欧美大片久久久| 午夜精品成人在线视频| 成人午夜影视| 成人午夜影院在线观看| 久久久亚洲人| 2021亚洲天堂| 亚洲欧美日韩精品久久亚洲区| 日韩有码欧美| 黄网站欧美内射| 国产精品色在线| 日本精品一二区| 国产精品一区二区久久精品| 欧美三级不卡| 国产18无套直看片| 欧美成人精品高清在线播放| 日韩一区二区三区在线免费观看| 中文字幕一区二区三区在线乱码 | 粉嫩一区二区三区在线观看| 国产原创中文在线观看 | 暴力调教一区二区三区| 波多野结衣黄色网址| 欧美巨乳美女视频| 波多野结衣在线播放一区|