多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當前位置:首頁 > 互聯(lián)網(wǎng) > Leetcode 動態(tài)規(guī)劃 Unique Paths

Leetcode 動態(tài)規(guī)劃 Unique Paths

來源:程序員人生   發(fā)布時間:2014-09-08 17:09:21 閱讀次數(shù):2351次

本文為senlie原創(chuàng),轉載請保留此地址:http://blog.csdn.net/zhengsenlie


Unique Paths

 Total Accepted: 17915 Total Submissions: 57061My Submissions

A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below).

The robot can only move either down or right at any point in time. The robot is trying to reach the bottom-right corner of the grid (marked 'Finish' in the diagram below).

How many possible unique paths are there?


Above is a 3 x 7 grid. How many possible unique paths are there?

Note: m and n will be at most 100.




題意:給定一個 m * n 的網(wǎng)格,一個機器人要從左上角走到右下角,每次只能向下或向右移動一個位置,
問有多少種走法
思路1:dfs暴力枚舉
復雜度:超時了... O(2^n)

思路2:記憶化搜索

用一個數(shù)組paths[i][j]記錄從 (0,0) 到 (m,n)的路徑數(shù)

思路3:dp
設置狀態(tài)為f[i][j],表示從(0,0)到達網(wǎng)格(i,j)的路徑數(shù),則狀態(tài)轉移方程為
f[i][j] = f[i - 1][j] + f[i][j - 1]
復雜度:時間O(n^2) 空間 O(n)

<pre name="code" class="cpp">//思路1 int uniquePaths(int m, int n){ if(m < 0 || n < 0) return 0; if(m == 1 && n == 1) return 1; return uniquePaths(m - 1, n) + uniquePaths(m, n - 1); } //思路2 //paths[i][j]表示從(0,0)到(i,j)的路徑數(shù) int paths[101][101]; int dfs(int m, int n){ if(m < 0 || n < 0) return 0; if(m == 1 && n == 1) return 1; if(paths[m][n] >= 0) return paths[m][n]; return paths[m][n] = dfs(m - 1, n) + dfs(m, n - 1); } int uniquePaths(int m, int n){ memset(paths, -1, sizeof(paths)); return dfs(m, n); } //思路2另一種寫法 //paths[i][j]表示從(i,j)到(m - 1,n - 1)的路徑數(shù) int paths[101][101]; int mm, nn; int dfs(int x, int y){ if(x >= mm || y >= nn) return 0; if(x == mm - 1 && y == nn - 1) return 1; if(paths[x][y] >= 0) return paths[x][y]; return paths[x][y] = dfs(x + 1, y) + dfs(x, y + 1); } int uniquePaths(int m, int n){ mm = m, nn = n; memset(paths, -1, sizeof(paths)); return dfs(0, 0); } //思路3 paths[i][j] 表示(0, 0) 到(i,j)的路徑數(shù) int paths[101][101]; int uniquePaths(int m, int n){ memset(paths, 0, sizeof(paths)); for(int i = 0; i < m; ++i) paths[i][0] = 1; for(int j = 0; j < n; ++j) paths[0][j] = 1; for(int i = 1 ; i < m; ++i){ for(int j = 1; j < n; ++j){ paths[i][j] = paths[i - 1][j] + paths[i][j - 1]; } } return paths[m - 1][n - 1]; } 思路3 另一種寫法 用一個一維數(shù)組 paths[j] 表示 (0, 0) 至 (i, j)的路徑數(shù),在外循環(huán)變量為 i 時,還沒更新前 paths[j] 對應上面二維數(shù)組寫法的paths[i - 1, j],paths[j - 1]對應paths[i][j - 1] int paths[101]; int uniquePaths(int m, int n){ memset(paths, 0, sizeof(paths)); paths[0] = 1; for(int i = 0; i < m; ++i){ for(int j = 1; j < n; ++j){ paths[j] = paths[j] + paths[j - 1]; } } return paths[n - 1]; }





生活不易,碼農辛苦
如果您覺得本網(wǎng)站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 亚洲经典自拍 | 中文乱码一二三四有限公司 | 亚洲看片网站 | 国产亚洲精品久久久久久小说 | 好大好湿好硬顶到了好爽(双性) | 极品一区 | 性做久久 | 国内精品久久久久影 | 中文在线免费视频 | 日本一区二区在线播放 | 午夜久久久精品 | 久久久久免费 | 亚欧综合| 欧美一区二区精品系列在线观看 | 久久精品国产亚洲a | 狠久久 | 国产欧美另类久久久品 | 久久乐国产精品亚洲综合18 | 久草在线视频福利 | 久久久久久国产精品三级 | 怡红院免费的全部视频国产a | 美女免费视频是免费网站 | jizzjizz免费大全 | 91久久亚洲精品国产一区二区 | 一本久道热中字伊人 | 日韩精品亚洲人成在线播放 | 欧美中文小说在线观看 | 国产成人亚洲精品无广告 | 亚洲最新在线视频 | 日韩在线手机看片免费看 | 欧美亚洲一级片 | 亚洲免费久久 | 中文字幕免费播放 | 国产综合精品久久亚洲 | 国内自拍视频网站 | 香蕉狠狠再啪线视频 | 亚洲欧美视频一级 | 性欧美日韩 | 中文字幕在线观看 | 黑人高h | 日本高清免费视频色www |