博客
关于我
leetcode 63. Unique Paths II
阅读量:134 次
发布时间:2019-02-26

本文共 2697 字,大约阅读时间需要 8 分钟。

一 题目

  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).

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.

Note: m and n will be at most 100.

Example 1:

Input:[  [0,0,0],  [0,1,0],  [0,0,0]]Output: 2Explanation:There is one obstacle in the middle of the 3x3 grid above.There are two ways to reach the bottom-right corner:1. Right -> Right -> Down -> Down2. Down -> Down -> Right -> Right

二 分析

   medium级别,这个题目跟上一个差不多,区别就是这个加了障碍物。

所以解题思路一样。区别是加了障碍物的判断。

DFS

public static void main(String[] args) {		// TODO Auto-generated method stub		int[][] obstacleGrid ={				{0,0,0},				{0,1,0},				{0,0,0}		};	int res = uniquePathsWithObstacles( obstacleGrid);	System.out.println(res);		}    //dfs	public static int uniquePathsWithObstacles(int[][] obstacleGrid) {		int m = obstacleGrid.length;		int n = obstacleGrid[0].length;		 if (obstacleGrid[0][0] != 0 ||	                obstacleGrid[m - 1][n - 1] != 0) return 0;		int[][] f = new int[m][n];		f[0][0] = obstacleGrid[0][0]==0?1:0;		return dfs(m-1,n-1,f,obstacleGrid);				    }		static int dfs(int x, int y, int[][] f,int[][] obstacleGrid) {        if (x < 0 || y < 0) return 0; // 数据非法,终止条件             if(obstacleGrid[x][y]==1){//障碍物        	return 0;        }        if (x == 0 && y == 0) return f[0][0]; // 回到起点,收敛条件                if (f[x][y] > 0) {            return f[x][y];        } else {            return f[x][y] = dfs(x - 1, y,f,obstacleGrid) +  dfs(x, y - 1,f,obstacleGrid);        }    }

Runtime: 4 ms, faster than 5.18% of Java online submissions for Unique Paths II.

Memory Usage: 40.9 MB, less than 15.38% of Java online submissions for Unique Paths II.

动态规划

  使用一个二维的 dp 数组,这里的 dp[i][j] 表示到达 (i, j) 位置的不同路径的数量,状态转移方程跟之前的一样:每个位置只能由其上面和左面的位置移动而来,也是由其上面和左边的 dp 值相加来更新当前的 dp 值,如下所示:

dp[i][j] = dp[i-1][j] + dp[i][j-1]

  另外,最上面的一行跟最左边的行初始化要判断下,不能全部为1,遇到障碍物就是0。

public static void main(String[] args) {		int[][] obstacleGrid ={				{0,0,0},				{0,1,0},				{0,0,0}		};	int res = uniquePathsWithObstacles( obstacleGrid);	System.out.println(res);		}		public static int uniquePathsWithObstacles(int[][] obstacleGrid) {		int m = obstacleGrid.length;		int n = obstacleGrid[0].length;				int[][] dp = new int[m][n];		//初始化第0列		for(int i=0;i

Runtime: 0 ms, faster than 100.00% of Java online submissions for Unique Paths II.

Memory Usage: 39.3 MB, less than 61.54% of Java online submissions for Unique Paths II.

时间复杂度O(M*N).

 

 

转载地址:http://ardy.baihongyu.com/

你可能感兴趣的文章
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>