【算法日志】动态规划刷题:路径数问题(day34)

代码随想录刷题60Day


目录

前言

不同路径

不同路径(2)


前言

今天的动态规划题与昨天的题很类似,只不过今天的题是在二维上讨论,难度上略有提升。


不同路径

cpp 复制代码
int uniquePaths(int m, int n) 
	{
		vector<int> dp(n + 1, 1);
		for (int i = 1; i < m; ++i)
		{
			for (int j = 2; j <= n; ++j)
				dp[j] = dp[j] + dp[j - 1];
		}
		return dp[n];
	}

不同路径(2)

有一些测试用例比较极端,需要注意一些细节。

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

相关推荐
BirdenT23 分钟前
20260519紫题训练
c++·算法
csdn_aspnet6 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士6 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji9 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言11 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
圣保罗的大教堂11 小时前
leetcode 796. 旋转字符串 简单
leetcode
kyle~11 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学11 小时前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行12 小时前
并发编程(一)
java·jvm·算法
z2005093012 小时前
今日算法(依旧二叉树)
算法·leetcode·职场和发展