leetcode542 01矩阵

一、问题描述

二、解题思路

可以使用多源bfs的方法来解决这个问题,由于本题需要聚焦到每一个为1的位置。所以,需要定义一个dis向量来记录1到最近的0的距离,所有元素值初始化为-1。解题思路如下:

(1)首先,遍历mat,将matij==0的(i,j)入队,并将disij由-1修改为0,表示其到最近的0的距离为0;

(2)接下来进行bfs。将队头元素弹出,遍历其四周,如果坐标不越界且disnext_xnext_y==-1,即该位置为1且未被辐射到,就将其dis值修改为discur_xcur_y+1。

辐射完后,返回dis,即为所求。

三、代码实现

cpp 复制代码
class Solution {
    int N,M;
    vector<vector<int>> dis;

    int dx[4]={0,1,0,-1};
    int dy[4]={-1,0,1,0};
public:
    vector<vector<int>> updateMatrix(vector<vector<int>>& mat) {
        //多源bfs(以0为中心进行扩散)
        //全局变量初始化
        N=mat.size();M=mat[0].size();
        dis.resize(N,vector(M,-1));

        //遍历mat将0入队并更新其dis
        queue<pair<int,int>> q;
        for(int i=0;i!=N;i++)
            for(int j=0;j!=M;j++)
                if(mat[i][j]==0){
                    q.push({i,j});
                    dis[i][j]=0;
                }
        //bfs
        while(!q.empty()){
            pair<int,int> cur=q.front();q.pop();
            int cur_x=cur.first;
            int cur_y=cur.second;
            for(int i=0;i!=4;i++){
                int next_x=cur_x+dx[i];
                int next_y=cur_y+dy[i];
                if(next_x>=0&&next_x<N&&next_y>=0&&next_y<M&&dis[next_x][next_y]==-1){
                    q.push({next_x,next_y});
                    dis[next_x][next_y]=dis[cur_x][cur_y]+1;
                }
            }
        } 
        return dis;
    }
};
相关推荐
原来是猿1 小时前
理解 C++ 哈希表的原理与工程实践
开发语言·c++·散列表
wu_ye_m1 小时前
学习c语言第34天 用函数每次输出+1,链式访问,int和void
c语言·学习·算法
Lucky_ldy1 小时前
数据结构从入门到精通:链表的分类
数据结构·链表
牢姐与蒯1 小时前
c++数据结构之c++11(二)
开发语言·c++
星马梦缘1 小时前
算法设计与分析 作业三 答案与解析
算法·线性规划·二分图匹配·多元最短路·流网络·bellmanford·匈牙利树算法
lcj25111 小时前
【stack、queue、deque、priority_queue】C++ 栈 / 队列 / 优先级队列全解析!手撕实现 + 二叉树层序遍历(附源码)
开发语言·c++·笔记
微风欲寻竹影1 小时前
Java数据结构——二叉树相关OJ题目详解
java·数据结构
兵哥工控1 小时前
高精度微秒延时函数实现顺控工控项目实例
c++·mfc·硬件高精度计时器
微风欲寻竹影1 小时前
Java数据结构——二叉树(Binary Tree)详解
java·数据结构·算法