【算法与数据结构】63、LeetCode不同路径 II

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

思路分析:参考【算法与数据结构】62、LeetCode不同路径的题目,可以发现本题仅仅是多了障碍物。我们还是用动态规划来做。有障碍物的地方无法到达,因此路径数量为0,只需要将障碍物位置的dp数组记为0,除此之外障碍物后面的位置有可能无法到达(程序当中的两个if break语句)。

程序如下:

cpp 复制代码
class Solution {
public:
	int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
		int row = obstacleGrid.size(), col = obstacleGrid[0].size();
		vector<vector<int>> dp(row, vector<int>(col, 0));
		for (int i = 0; i < col; i++) {
			if (obstacleGrid[0][i] == 1) break;
			dp[0][i] = 1;
		}
		for (int j = 0; j < row; j++) {
			if (obstacleGrid[j][0] == 1) break;
			dp[j][0] = 1;
		}
		for (int i = 1; i < row; i++) {
			for (int j = 1; j < col; j++) {
				if (obstacleGrid[i][j] == 0) dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
				else dp[i][j] = 0;
			}
		}
		return dp[row - 1][col - 1];
	}
};

复杂度分析:

  • 时间复杂度: O ( r o w ∗ c o l ) O(row*col) O(row∗col),,row和col分别是地图的行和列。
  • 空间复杂度: O ( r o w ∗ c o l ) O(row*col) O(row∗col)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <vector>
using namespace std;

class Solution {
public:
	int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
		int row = obstacleGrid.size(), col = obstacleGrid[0].size();
		vector<vector<int>> dp(row, vector<int>(col, 0));
		for (int i = 0; i < col; i++) {
			if (obstacleGrid[0][i] == 1) break;
			dp[0][i] = 1;
		}
		for (int j = 0; j < row; j++) {
			if (obstacleGrid[j][0] == 1) break;
			dp[j][0] = 1;
		}
		for (int i = 1; i < row; i++) {
			for (int j = 1; j < col; j++) {
				if (obstacleGrid[i][j] == 0) dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
				else dp[i][j] = 0;
			}
		}
		return dp[row - 1][col - 1];
	}
};

int main() {
	//vector<vector<int>> obstacleGrid = { {0, 0, 0}, {0, 1, 0}, { 0, 0, 0 } };
	vector<vector<int>> obstacleGrid = { {0, 1}, {0, 0} };
	Solution s1;
	int result = s1.uniquePathsWithObstacles(obstacleGrid);
	cout << result << endl;
	system("pause");
	return 0;
}

end

相关推荐
ZShiJ16 分钟前
【题解】—— LeetCode一周小结27
算法·leetcode·职场和发展
振华首席娱记1 小时前
代码随想录——划分字母区间(Leetcode763)
java·数据结构·算法·leetcode·职场和发展
阳光男孩011 小时前
力扣3026.最大好子数组和
数据结构·算法·leetcode
Eliauk &1 小时前
【机器学习】分类算法-KNN算法实现
人工智能·python·算法·机器学习·分类
littlesujin1 小时前
昇思25天打卡营-mindspore-ML- Day15-K近邻算法实现红酒分类
算法·分类·近邻算法
Dalao_zzl1 小时前
C语言实现的冒泡排序算法的示例程序
c语言·算法·排序算法
悄悄敲敲敲1 小时前
栈的实现详解
c语言·开发语言·数据结构·c++·算法·链表·线性回归
danaaaa1 小时前
算法力扣刷题总结篇 ——【四】
数据结构·c++·算法·leetcode·职场和发展
亚图跨际2 小时前
C++和Python蚂蚁搬食和蚊虫趋光性和浮标机群行为算法神经网络
算法·集群机·耦合共振同步动作·分子间势能·寻觅同伴·统计学量化集群·可视化集群运动
安於宿命2 小时前
0/1背包问题总结
c语言·c++·算法·leetcode·动态规划