亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

62. Unique Paths / 63. Unique Paths II

2019-11-10 18:25:13
字體:
來源:轉載
供稿:網友

Unique Paths題目描述解法描述Unique Paths II題目描述實現代碼

62. Unique Paths

題目描述

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?

一個矩陣mxn,從左上角到右下角有多少條路徑。

解法描述

法一:使用深度搜索。這種方法會超時。

class Solution {public: void uniquePathsNum(int &res, int m, int n, int i, int j, int stt) { if(i > m || j > n) return; if(stt >= m+n - 2) { if(m == i && n == j) {res++; return;} else return; } uniquePathsNum(res, m, n, i+1, j, stt+1); uniquePathsNum(res, m, n, i, j+1, stt+1); } int uniquePaths(int m, int n) { int res = 0; uniquePathsNum(res, m, n, 1, 1, 0); return res; }};

法二:使用DP來計算。

class Solution {public: int uniquePaths(int m, int n) { /* int **tmp = new int*[m+1]; for(int k = 0; k <= m; k++) tmp[k] = new int[n+1]; */ int tmp[101][101] = {0}; tmp[1][1] = 1; // cout << tmp[0][1] << endl; for(int i = 1; i <= m; i++) { for(int j = 1; j <= n; j++) { tmp[i][j] += (tmp[i-1][j] + tmp[i][j-1]); // cout << i << " " << j << " " << tmp[i][j] << " " << tmp[i-1][j] << " " << tmp[i][j-1] << endl; } } int res = tmp[m][n]; /* for(int i = 0; i <= m; i++) delete tmp[i]; delete tmp; */ return res; }};

使用空間復雜度O(n)的代碼:

class Solution {public: int uniquePaths(int m, int n) { int *memo = new int[n]; for(int i = 0; i < n; i++) memo[i] = 1; for(int i = 1 ; i < m; i++) for(int j = 1; j < n; j++) memo[j] += memo[j-1]; return memo[n-1]; }};

當然這道題還有方法,那就是使用高中學過的排列組合。

class Solution {public: int uniquePaths(int m, int n) { if(m == 1 || n == 1) return 1; m--; n--; if(m < n) { // Swap, so that m is the bigger number m = m + n; n = m - n; m = m - n; } long res = 1; int j = 1; for(int i = m+1; i <= m+n; i++, j++){ // Instead of taking factorial, keep on multiply & divide res *= i; res /= j; } return (int)res; }};class Solution {public: int uniquePaths(int m, int n) { return nCr (m + n - 2, min(m, n) - 1); }PRivate: int nCr (int n, int r) { long long_result = 1; for (int i = 0; i != r; ++i) { // from n - r + 1 (when i = 0) to n (when i = r - 1) long_result *= (n - r + 1 + i); // from 1 (when i = 0) to r (when i = r - 1) long_result /= (i + 1); } return (int) long_result; }};

63. Unique Paths II

題目描述

Follow up for "Unique Paths":Now consider if some obstacles are added to the grids. How many unique paths would there be?An obstacle and empty space is marked as 1 and 0 respectively in the grid.For example,There is one obstacle in the middle of a 3x3 grid as illustrated below.[ [0,0,0], [0,1,0], [0,0,0]]The total number of unique paths is 2.Note: m and n will be at most 100.

實現代碼

class Solution {public: int uniquePathsWithObstacles(vector<vector<int>>& g) { int row = g.size(); int column = row > 0?g[0].size():0; int v[101][101] = {0}; v[1][1] = 1 - g[0][0]; for(int i = 1; i <= row; i++) { for(int j = 1; j <= column; j++) { if((i != 1 || j != 1) && g[i-1][j-1]) v[i][j] = 0; else v[i][j] += v[i-1][j] + v[i][j-1]; } } return v[row][column]; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97婷婷大伊香蕉精品视频| 欧美在线一级视频| 亚洲成avwww人| 国产精品91在线| 日韩理论片久久| 黑人巨大精品欧美一区二区免费| 色狠狠久久aa北条麻妃| 欧美性猛交xxxx偷拍洗澡| 国内精品久久久| 色小说视频一区| 欧美激情欧美激情| 国产精品嫩草视频| 亚洲精品久久久久久久久久久久| 国内精品久久久久影院 日本资源| 精品日韩美女的视频高清| 亚洲精品在线91| 欧美日韩激情视频8区| 日韩美女写真福利在线观看| 国产视频精品va久久久久久| 欧美日韩在线影院| 亚洲综合在线播放| 成人免费在线视频网站| 久久亚洲精品中文字幕冲田杏梨| 综合国产在线观看| 欧美亚洲伦理www| 国产精品久久久久久婷婷天堂| 97视频在线播放| 国产精品6699| 奇米成人av国产一区二区三区| 亚洲一区二区三区在线视频| 欧洲美女7788成人免费视频| 综合网日日天干夜夜久久| 国产一区二区三区日韩欧美| 国产精品影院在线观看| 亚洲一区二区三区777| 精品中文字幕在线观看| 欧美在线视频免费| 国产精品电影网站| 国产精品国产亚洲伊人久久| 久久青草福利网站| 91免费国产视频| 国产成人aa精品一区在线播放| 欧美有码在线视频| 北条麻妃99精品青青久久| 在线播放国产一区二区三区| 亚洲毛片在线观看| 成人欧美在线视频| 亚洲精品国产精品国自产在线| 欧美极品美女视频网站在线观看免费| 色青青草原桃花久久综合| 日韩欧美在线视频| 国产精品91在线观看| 日韩日本欧美亚洲| 菠萝蜜影院一区二区免费| 日韩精品高清在线| 欧美在线性视频| 欧美精品videos| 欧美日本国产在线| 91极品视频在线| 国产精品久久久久aaaa九色| 欧美色道久久88综合亚洲精品| 国产日本欧美一区| 国模吧一区二区三区| 国产小视频91| 欧美日韩亚洲高清| 国产精品久久久久久av福利软件| 情事1991在线| 日韩亚洲成人av在线| 欧美一区二区三区免费视| 久久久伊人欧美| 精品国产乱码久久久久久天美| 欧美噜噜久久久xxx| 日韩激情在线视频| 日韩av片永久免费网站| 这里只有精品在线观看| 欧美极品第一页| 日本成人精品在线| 亚洲精品中文字幕av| 欧美日韩美女视频| 亚洲激情视频在线| 综合网中文字幕| 成人福利网站在线观看11| 欧美大尺度电影在线观看| 欧美电影在线免费观看网站| 国产精品久久电影观看| 成人性生交大片免费看视频直播| 国产精品免费久久久久久| www.亚洲男人天堂| xxx一区二区| 亚洲一二三在线| 成人精品一区二区三区电影黑人| 另类天堂视频在线观看| 亚洲人午夜精品| 97精品国产97久久久久久春色| 岛国av一区二区在线在线观看| 国产精品高潮呻吟久久av无限| 亚洲成人在线视频播放| 黄色精品一区二区| 日韩av三级在线观看| 福利精品视频在线| 国产精品久久久久久久久久尿| 成人在线国产精品| 国产精品美女视频网站| 日韩欧美亚洲一二三区| 日本精品va在线观看| 国产一区二区三区在线观看视频| 91久久国产精品91久久性色| 久久精品国产亚洲精品| 91精品国产91久久久久久吃药| 精品视频久久久久久| 国产精品欧美亚洲777777| 北条麻妃在线一区二区| 一区二区三区国产视频| 国产精品男人的天堂| 国产欧美一区二区三区久久| 欧美视频在线免费| 亚洲国产精品yw在线观看| 久久久亚洲影院| 亚洲乱码一区av黑人高潮| 日韩高清免费观看| www.久久色.com| 国产精品久久久久77777| 欧美高清激情视频| 亚洲欧美日韩爽爽影院| 国产日韩在线免费| 欧洲亚洲女同hd| 国产综合香蕉五月婷在线| 久久久欧美一区二区| 亚洲精品二三区| 成人久久久久爱| 日韩欧美国产免费播放| 久久天天躁狠狠躁夜夜躁2014| 91欧美精品成人综合在线观看| 中文字幕欧美日韩精品| 国产精品露脸自拍| 欧美在线视频观看免费网站| 神马久久久久久| 国产精品海角社区在线观看| 最近更新的2019中文字幕| 欧美另类精品xxxx孕妇| 日韩成人高清在线| 日韩av不卡在线| 日韩免费观看在线观看| 91麻豆桃色免费看| 久久久久久香蕉网| 国产一区二中文字幕在线看| 一区二区在线免费视频| 国产精品视频最多的网站| 91久久国产精品91久久性色| 国产成人在线视频| 热99精品里视频精品| 久久99亚洲精品| 亚洲热线99精品视频| 久久人人97超碰精品888| 欧美xxxx18性欧美| 欧美性高跟鞋xxxxhd| 正在播放国产一区| 精品久久久久人成| 亚洲天堂成人在线视频| 91精品国产91久久久久久最新| 亚洲日韩欧美视频| 国产不卡av在线| 狠狠综合久久av一区二区小说| 国产一区av在线|