【LeetCode】动态规划——542.01 矩阵

LeetCode题目链接

https://leetcode.cn/problems/01-matrix/description/

题解

从左上到右下扫描一遍、从右下到左上扫描一遍,初始化全矩阵中为0的值对应的dp数组距离为0(注意错误思路"从四周初始化")。扫描时,不用再注意对应mat[i][j]值是否为1还是0,而是对全数组都进行min的判断,并且判断里要分两种情况,一种是左侧,一种是上侧(以及一种是右侧,一种是下侧),因此,就要对下标进行边界判断,只要不在初始边界出界的情况下都判断两侧,判断时,由于0已经初始化为了0,为1时自动判断是否+1为最小,而0永远不变,因此可以得出不判断0和1的情况所得的dp数组是正确的。

代码

cpp 复制代码
//542.01矩阵
#include <iostream>
#include <vector>
using namespace std;

class Solution {
public:
    vector<vector<int>> updateMatrix(vector<vector<int>>& mat) {
        vector<vector<int>> dp(mat.size(),vector<int>(mat[0].size(), INT_MAX / 2));
        //初始化
        for (int i = 0;i < mat.size();i++) {
            for (int j = 0;j < mat[0].size();j++) {
				if (mat[i][j] == 0) {
					dp[i][j] = 0;
				}
            }
        }
        //看前面的不看后面的
        for (int i = 0;i < mat.size();i++) {
            for (int j = 0;j < mat[0].size();j++) {
                if (i > 0) dp[i][j] = min(dp[i][j], dp[i - 1][j] + 1);
                if (j > 0) dp[i][j] = min(dp[i][j], dp[i][j - 1] + 1);
            }
        }
        for (int i = mat.size() - 1;i >= 0;i--) {
            for (int j = mat[0].size() - 1;j >= 0;j--) {
                if (i < mat.size() - 1) dp[i][j] = min(dp[i][j], dp[i + 1][j] + 1);
                if (j < mat[0].size() - 1) dp[i][j] = min(dp[i][j], dp[i][j + 1] + 1);
            }
        }
        //递推公式
        return dp;
    }
};

int main() {
    Solution s;
    vector<vector<int>> mat = {
        {0},
        {0},
        {0},
        {0},
        {0}
    };
    vector<vector<int>> result = s.updateMatrix(mat);
    for (int i = 0;i < result.size();i++) {
		for (int j = 0;j < result[0].size();j++) {
			cout << result[i][j] << " ";
		}
		cout << endl;
    }
	return 0;
}
相关推荐
Asmalin7 小时前
【代码随想录day 35】 力扣 01背包问题 一维
算法·leetcode·职场和发展
剪一朵云爱着7 小时前
力扣2779. 数组的最大美丽值
算法·leetcode·排序算法
tao3556677 小时前
【Python刷力扣hot100】283. Move Zeroes
开发语言·python·leetcode
未知陨落8 小时前
LeetCode:98.颜色分类
算法·leetcode
Haooog11 小时前
98.验证二叉搜索树(二叉树算法题)
java·数据结构·算法·leetcode·二叉树
Young_Zn_Cu13 小时前
LeetCode刷题记录(持续更新中)
算法·leetcode
天选之女wow14 小时前
【代码随想录算法训练营——Day31】贪心算法——56.合并区间、738.单调递增的数字、968.监控二叉树
算法·leetcode·贪心算法
Miraitowa_cheems17 小时前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
_不会dp不改名_18 小时前
leetcode_1382 将二叉搜索树变平衡树
算法·leetcode·职场和发展
Q741_14720 小时前
C++ 位运算 高频面试考点 力扣 面试题 17.19. 消失的两个数字 题解 每日一题
c++·算法·leetcode·面试·位运算