博客
关于我
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/

你可能感兴趣的文章
MySQL查看数据库相关信息
查看>>
MySQL查看表结构和表中数据
查看>>
MySQL查询优化:LIMIT 1避免全表扫描
查看>>
MySQL查询优化之索引
查看>>
mysql查询储存过程,函数,触发过程
查看>>
mysql查询总成绩的前3名学生信息
查看>>
mysql查询慢排查
查看>>
MySQL查询报错ERROR:No query specified
查看>>
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>