题目链接: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?
Note: m and n will be at most 100.
这道题的要求是计算机器人从左上角移动到右下角有多少不同的路径(机器人每次只能向右或是向下移动1格)。
-
动态规划
这是一道简单的动态规划问题,假设机器人当前在[i, j]位置,由于其只能向下或向右移动,因此只能由[i, j-1]和[i-1, j]这两位置移动到[i, j]。因此到达[i, j]位置的不同路径数量为[i, j-1]和[i-1, j]两位置的路径数量之和,即dp[i][j] = dp[i][j-1] + dp[i-1][j]。
时间复杂度:O(mn)
空间复杂度:O(mn)
1
2
3
4
5
6
7
8
9
10
11
12
class Solution{
public:
int uniquePaths(int m, int n)
{
vector<vector<int> > vvi(m + 1, vector<int>(n + 1, 0));
vvi[0][1] = 1;
for(int i = 1; i <= m; ++ i)
for(int j = 1; j <= n; ++ j)
vvi[i][j] = vvi[i][j - 1] + vvi[i - 1][j];
return vvi[m][n];
}
};
-
组合问题
这同样是一道组合问题。由于机器人只能向下或向右移动,因此从左上角移动到右下角,需要向下移动m-1步,向右移动n-1步,即在m+n-2步中选出m-1步向下移动或是选出n-1步向右移动,即C(m+n-2, m-1)或C(m+n-2, n-1)。令minmn为m和n中的较小值,则共有C(m+n-2, minmn-1)不同路径。
至于求组合数,可以利用杨辉三角,逐层加出来即可。
时间复杂度:O((m+n)*min(m,n))
空间复杂度:O((m+n)*min(m,n))
1
2
3
4
5
6
7
8
9
10
11
12
class Solution{
public:
int uniquePaths(int m, int n)
{
vector<vector<int> > vvi(m + 1, vector<int>(n + 1, 0));
vvi[0][1] = 1;
for(int i = 1; i <= m; ++ i)
for(int j = 1; j <= n; ++ j)
vvi[i][j] = vvi[i][j - 1] + vvi[i - 1][j];
return vvi[m][n];
}
};