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

【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.xdnf.cn/news/19005.html

相关文章:

  • 系统设计(数据库/微服务)
  • 计算机网络的发展演进历程
  • 2 梯度下降算法
  • 英伟达 Spectrum-XGS:重构 AI 基础设施,开启跨域超级工厂时代
  • 氯化钕:以稀土之力引领科技创新
  • Spring AI 入门指南:三步将AI集成到Spring Boot应用
  • Java大厂面试实战:从Spring Boot到微服务架构的全链路技术剖析
  • MySQL 面试题系列(四)
  • Mysql——日志
  • 力扣hot100:搜索旋转排序数组和寻找旋转排序数组中的最小值(33,153)
  • TikTok广告投放革命:指纹云手机如何实现智能群控与降本增效
  • Mac中修改Word的Normal.dotm文件
  • CSS实现内凹圆角边框技巧(高频)
  • 绿算技术解密金融科技安全:高性能计算与存储驱动金融防火墙新时代
  • 【拥抱AI】一起学卷积神经网络(CNN)
  • 一天推荐一款实用的手柄零件————线性霍尔
  • Zynq开发实践(FPGA之verilog仿真)
  • Flask 之上下文详解:从原理到实战
  • OSG+Qt —— 笔记3- Qt窗口绘制模型的三条轴(附源码)
  • 【Linux操作系统】简学深悟启示录:环境变量进程地址
  • Mysql面试题分享
  • 医疗巡诊车5G专网路由器应用
  • webrtc音频QOS方法一.1(NetEQ之音频网络延时DelayManager计算补充)
  • Spring Boot 与传统 Spring:从 WAR 到可执行 JAR,颠覆性的部署哲学
  • 在 TencentOS 3 上部署 OpenTenBase:从底层原理到生产级实践的深度指南
  • 微服务-24.网关登录校验-实现登录校验
  • 网站开发用什么语言好
  • 数据结构:链式队列尝试;0826
  • 庖丁解牛:深入解析Oracle SQL语言的四大分类——DML、DDL、DCL、TCL
  • Rust 环境搭建与 SeekStorm 项目编译部署(支持中文)