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

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

62. Unique Paths / 63. Unique Paths II

2019-11-10 19:07:47
字體:
來源:轉載
供稿:網友

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
孩xxxx性bbbb欧美| 日韩av影院在线观看| 美女视频黄免费的亚洲男人天堂| 在线观看国产欧美| 91精品视频在线| 日本国产精品视频| 国产精品稀缺呦系列在线| 亚洲国产精品久久久久秋霞不卡| 欧美黑人巨大精品一区二区| 91最新在线免费观看| 亚洲欧美成人在线| 黄色一区二区三区| 国产福利视频一区二区| 久久大大胆人体| 在线视频欧美日韩精品| 日韩欧美国产网站| 国产精品嫩草影院一区二区| 粗暴蹂躏中文一区二区三区| 色偷偷91综合久久噜噜| 国产日韩在线亚洲字幕中文| 久久视频在线播放| 国产成人精品在线播放| 国内成人精品视频| 亚洲精品98久久久久久中文字幕| 日韩欧美在线视频观看| 亚洲欧美视频在线| 欧美一性一乱一交一视频| 亚洲专区在线视频| 亚洲丝袜av一区| 91精品国产自产在线老师啪| 久久久久久久国产精品| 亚洲欧美中文日韩在线v日本| 欧美剧在线观看| 日韩精品极品毛片系列视频| 国产美女扒开尿口久久久| 九九精品在线视频| 亚洲成人精品视频在线观看| 国产成人综合精品| 国产精品福利无圣光在线一区| 疯狂做受xxxx欧美肥白少妇| 亚洲精品视频免费在线观看| 97**国产露脸精品国产| 久久综合久中文字幕青草| 国产精品露脸自拍| 成人国内精品久久久久一区| 国产精品天天狠天天看| 国产福利精品视频| 日韩最新av在线| 亚洲精品网址在线观看| 欧美区在线播放| 日韩欧美视频一区二区三区| 欧美激情va永久在线播放| 国产精品∨欧美精品v日韩精品| 伊人久久大香线蕉av一区二区| 精品一区二区三区四区在线| 亚洲欧洲在线观看| xvideos亚洲人网站| 日韩亚洲欧美成人| 成人网页在线免费观看| 亚洲精品乱码久久久久久按摩观| 日本人成精品视频在线| 精品视频在线观看日韩| 国产丝袜精品视频| 久久亚洲私人国产精品va| 永久免费看mv网站入口亚洲| 97超碰国产精品女人人人爽| 91精品视频播放| 97香蕉久久超级碰碰高清版| 久久亚洲国产精品成人av秋霞| 国产精品电影网| 国产日韩欧美中文| 国产日韩欧美影视| 日韩av网站电影| 精品国产91久久久| 色噜噜狠狠狠综合曰曰曰88av| 国产精品欧美日韩久久| 在线亚洲午夜片av大片| 亚洲深夜福利网站| 国产精品亚洲自拍| 久久精品夜夜夜夜夜久久| 欧美精品久久久久久久久| 成人免费午夜电影| 欧美日韩成人网| 久久久久国产精品一区| 最新69国产成人精品视频免费| 日韩免费在线免费观看| 日日骚av一区| 黄色91在线观看| 国产成人精品免高潮在线观看| 中文字幕国内精品| 欧美美女18p| 久久天天躁狠狠躁夜夜av| 亚洲影视中文字幕| 在线日韩日本国产亚洲| 2019av中文字幕| 欧美视频免费在线| 国产欧美日韩中文字幕在线| 亚洲国产精久久久久久久| 色婷婷综合成人| 国产精品日日摸夜夜添夜夜av| 欧美性猛交xxxxx免费看| 国产精品久久久久久久久免费| 亚洲第一精品久久忘忧草社区| 久久天天躁狠狠躁夜夜躁2014| 欧美片一区二区三区| 日韩电影大片中文字幕| 国产91精品久久久久| 欧美成人一区二区三区电影| 久久成人在线视频| 亚洲精品午夜精品| 久久视频中文字幕| 青青精品视频播放| 91视频免费在线| 中文字幕av日韩| 97在线免费观看视频| 精品久久久中文| 深夜福利国产精品| 91网站在线免费观看| 久久久久国色av免费观看性色| 北条麻妃一区二区三区中文字幕| 久久精品99国产精品酒店日本| 懂色aⅴ精品一区二区三区蜜月| 国产精品高清网站| 日韩精品极品毛片系列视频| 91成人福利在线| 久久免费少妇高潮久久精品99| 国产999在线| 日本韩国在线不卡| 日韩av片永久免费网站| 欧美高清在线观看| 亚洲欧美福利视频| 高清视频欧美一级| 日韩国产激情在线| 国产成人一区二区三区电影| 136fldh精品导航福利| 亚洲人成免费电影| 欧美精品第一页在线播放| 亚洲欧洲日产国产网站| 日韩视频在线观看免费| 日韩成人在线免费观看| 久久亚洲一区二区三区四区五区高| 亚洲在线第一页| 性欧美亚洲xxxx乳在线观看| 2019中文字幕在线| 久久久久免费精品国产| 日本成人黄色片| 久久综合国产精品台湾中文娱乐网| 色狠狠av一区二区三区香蕉蜜桃| 国语自产精品视频在线看抢先版图片| 国产精品久久77777| 91色琪琪电影亚洲精品久久| 亚洲免费视频在线观看| 国产精品久久久久久久久久免费| 亚洲色图综合网| 91精品国产综合久久香蕉| 国产美女精彩久久| 久久久久国产精品www| 国产91热爆ts人妖在线| 亚洲xxxx妇黄裸体| 精品少妇一区二区30p| 91精品国产网站| 亚洲视频在线免费观看| 精品一区二区电影| 欧美精品videos性欧美|