当前位置: 首页 > news >正文

【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数组是正确的。

代码

//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;
}
http://www.dtcms.com/a/352079.html

相关文章:

  • GitHub Copilot Pro + 模型深度解析:Java 开发者场景适配指南
  • CSS 常见选择器
  • 【硬件-笔试面试题-62】硬件/电子工程师,笔试面试题(知识点:BUCK电源电路,输出纹波影响因素)
  • 代码架构升级方案
  • Docker中如何记录非交互式连接ssh用户操作的所有命令记录?
  • 2-5 倍性能提升,30% 成本降低,阿里云 SelectDB 存算分离架构助力波司登集团实现降本增效
  • docker compose小技巧
  • from中烟科技翼支付 面试题1
  • 红黑树下探玄机:C++ mapmultimap 的幕后之旅
  • deer-flow自定义DeepResearch流程实践经历
  • 《信息检索与论文写作》实验报告二 引文索引数据库检索
  • [pilot智驾系统] 纵向规划器(LongitudinalPlanner) | 模型预测控制(MPC)
  • jdk9安装步骤及下载(附小白详细教程)
  • 在Linux系统文件上次及下载
  • 《2025年最新IDE激活码永久破解教程 – 支持JetBrain全家桶2099年授权》
  • UE5安全架构审视:创造者的伊甸园与黑客的游乐场
  • pytorch入门4:cnn卷积神经网络
  • 《UE5_C++多人TPS完整教程》学习笔记44 ——《P45 倾斜与侧向移动(Leaning And Strafing)》
  • MoonBit Pearls Vol.06: MoonBit C-FFI 开发指南
  • 【新启航】现场逆向抄数实战:手持 3D 扫描仪 + 移动建模 APP 的轻量化工具组合与快速响应能力
  • 三款音乐生成工具,你更喜欢哪一个?
  • 如何在pixel上验证webview的功能
  • 服务初始化
  • 基于单张图像的深度估计方法研究:利用 Hugging Face 与 FiftyOne 实现单目深度估计模型的运行与评估
  • 从零开始学MCP(7) | 实战:用 MCP 构建论文分析智能体
  • 零基础从头教学Linux(Day 20)
  • javascript 基础知识- 字面量/内置对象
  • LVGL学习
  • 【设计模式】 面向对象基础
  • K8S-Service资源对象