leetcode 之 Unique Paths
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?

Above is a 3 x 7 grid. How many possible unique paths are there?
Note: m and n will be at most 100.
思路:典型的动态规划,dp[i][j]表示到matrix[i][j]的路径个数。则dp[i][j] = dp[i-1][j] + dp[i][j-1]。
int uniquePaths(int m, int n) {
if(m <=0 || n <= 0)return 0;
vector<vector<int> > dp(m);
int i,j;
for(i=0;i<m;i++)
{
vector<int> tmp(n,1);//至少一条
dp[i] = tmp;
}
for(i = 1;i < m;i++)
{
for(j = 1;j < n;j++)
{
dp[i][j] = dp[i-1][j] + dp[i][j-1];
}
}
return dp[m-1][n-1];
}
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.
思路:和上面类似,仅仅是当obstacleGrid[i][j] == 0时要把dp[i][j]=0。表示此路不通,初始化时也要注意
class Solution {
public:
int uniquePathsWithObstacles(vector<vector<int> > &obstacleGrid) {
int rows = obstacleGrid.size();
if(rows <= 0)return 0;
int cols = obstacleGrid[0].size();
if(cols <= 0)return 0;
vector<vector<int> > dp(rows);
int i,j;
for(i = 0;i < rows;i++)
{
vector<int> tmp(cols);
dp[i] = tmp;
}
dp[0][0] = obstacleGrid[0][0] == 0 ? 1 : 0;
for(i = 1;i < rows;i++)dp[i][0] = obstacleGrid[i][0] == 0 ? dp[i-1][0] : 0;//当为0时,不能简单的初始化为1。要初始化为前面的值,由于可能被前面挡住了
for(j = 1;j < cols;j++)dp[0][j] = obstacleGrid[0][j] == 0 ?
dp[0][j-1] : 0;
for(i = 1;i < rows;i++)
{
for(j = 1;j < cols;j++)
{
dp[i][j] = obstacleGrid[i][j] == 0 ? dp[i-1][j] + dp[i][j-1] : 0;
}
}
return dp[rows-1][cols-1];
}
};
public:
int uniquePathsWithObstacles(vector<vector<int> > &obstacleGrid) {
int rows = obstacleGrid.size();
if(rows <= 0)return 0;
int cols = obstacleGrid[0].size();
if(cols <= 0)return 0;
vector<vector<int> > dp(rows);
int i,j;
for(i = 0;i < rows;i++)
{
vector<int> tmp(cols);
dp[i] = tmp;
}
dp[0][0] = obstacleGrid[0][0] == 0 ? 1 : 0;
for(i = 1;i < rows;i++)dp[i][0] = obstacleGrid[i][0] == 0 ? dp[i-1][0] : 0;//当为0时,不能简单的初始化为1。要初始化为前面的值,由于可能被前面挡住了
for(j = 1;j < cols;j++)dp[0][j] = obstacleGrid[0][j] == 0 ? dp[0][j-1] : 0;
for(i = 1;i < rows;i++)
{
for(j = 1;j < cols;j++)
{
dp[i][j] = obstacleGrid[i][j] == 0 ? dp[i-1][j] + dp[i][j-1] : 0;
}
}
return dp[rows-1][cols-1];
}
};
版权声明:本文博客原创文章,博客,未经同意,不得转载。
leetcode 之 Unique Paths的更多相关文章
- LeetCode 63. Unique Paths II不同路径 II (C++/Java)
题目: A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). ...
- [LeetCode] 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 ...
- LeetCode 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 ...
- [LeetCode] 63. Unique Paths II_ Medium tag: Dynamic Programming
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
- [Leetcode Week12]Unique Paths II
Unique Paths II 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/unique-paths-ii/description/ Descrip ...
- [Leetcode Week12]Unique Paths
Unique Paths 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/unique-paths/description/ Description A ...
- [LeetCode] 63. Unique Paths II 不同的路径之二
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
- [LeetCode] 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 ...
- leetcode 62. Unique Paths 、63. Unique Paths II
62. Unique Paths class Solution { public: int uniquePaths(int m, int n) { || n <= ) ; vector<v ...
- 【leetcode】Unique Paths
A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...
随机推荐
- udacity android 学习笔记: lesson 4 part b
udacity android 学习笔记: lesson 4 part b 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...
- JAVA经BigDecimal圆角的解决方案及注意事项
/** * @Description: 四舍五入住宿2小数位数 * @param valueName * @return */ public static Double formateDouble45 ...
- CloudFoundry 中的GoRouter性能測试
之前一直感觉CloudFoundry的GoRouter的性能不靠谱,或者我们的CloudFoundry 部署架构存在问题,想着进行一些压力測试,可是一直苦于没有压力測试的工具.上一周,部门须要出一个測 ...
- String.format()【演示具体的例子来说明】
String.format()[演示样例具体解释] 整理者:Vashon 前言: String.format 作为文本处理工具.为我们提供强大而丰富的字符串格式化功能,为了不止步于简单调用 Strin ...
- pragma message任务
pragma message它是用来告诉程序猿,在编译的程序信息.和outputdebugstr则是告诉程序猿.程序在执行时期的信息. 以下就以一个样例来解说pragma message. 配合#if ...
- ASP.NET自定义控件组件开发 第四章 组合控件开发CompositeControl 后篇 --事件冒泡
原文:ASP.NET自定义控件组件开发 第四章 组合控件开发CompositeControl 后篇 --事件冒泡 CompositeControl 后篇 --事件冒泡 系列文章链接: ASP.NET ...
- 使用jQuery和css3实现了仿淘宝ued博客左边的菜单切换动画
今天看到淘宝ued博客的左侧导航菜单的动画好,要使用jQuery和css3我做一个简单的示例,主要用途是实现jQuery 事件和css3 transition属性. 个元素来实现鼠标滑动到某个导航的背 ...
- Oracle listener lsnrctl
lsnrctl(Listener Control)是一家SQL*Net具,用于控制数据库listener,此工具提供了控制命令listener开端.停止,查看listener状态,更改listener ...
- PHP于DIRECTORY_SEPARATOR任务
DIRECTORY_SEPARATOR是php的内部常量.用于显示系统分隔符的命令,不须要不论什么定义与包括就可以直接使用. 在windows下路径分隔符是\(当然/在部分系统上也是能够正常执行的), ...
- Codeforces Round #274 (Div. 2) --A Expression
主题链接:Expression Expression time limit per test 1 second memory limit per test 256 megabytes input st ...