LeetCode0542.01矩阵-创新互联

【LetMeFly】542.01 矩阵

力扣题目链接:https://leetcode.cn/problems/01-matrix/

10多年的偏关网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整偏关建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联公司从事“偏关网站设计”,“偏关网站推广”以来,每个客户项目都认真落实执行。

给定一个由01组成的矩阵mat,请输出一个大小相同的矩阵,其中每一个格子是mat中对应位置元素到最近的0的距离。

两个相邻元素间的距离为1

示例 1:

输入:mat = [[0,0,0],[0,1,0],[0,0,0]]
输出:[[0,0,0],[0,1,0],[0,0,0]]

示例 2:

输入:mat = [[0,0,0],[0,1,0],[1,1,1]]
输出:[[0,0,0],[0,1,0],[1,2,1]]

提示:

  • m == mat.length
  • n == mat[i].length
  • 1<= m, n<= 104
  • 1<= m * n<= 104
  • mat[i][j] is either 0 or 1.
  • mat中至少有一个
方法一:广度优先搜索

首先遍历原始矩阵,找到所有的0,将其位置入队。

接着在队列不为空时,不断出队一个位置,并判断这个位置的上下左右是否被遍历过。

如果还没有被遍历过,那么就将新的位置入队。并将地图中新的位置的值修改为“出队位置的值 + 1”

原理:

所有的原始的0最终结果都是0。广度优先搜索就是在所有的“0”的位置中,走一步。这一步所到的位置就是“1”步能到达的位置。同理,“1”经过一步到达的位置就是“2”。最先到达的就是步数最少的。

  • 时间复杂度 O ( n m ) O(nm) O(nm)
  • 空间复杂度 O ( n m ) O(nm) O(nm)
AC代码 C++
typedef pairpii;
const int direcitons[4][2] = {{-1, 0}, {1, 0}, {0, 1}, {0, -1}};
class Solution {public:
    vector>updateMatrix(vector>& mat) {int n = mat.size(), m = mat[0].size();
        vector>visited(n, vector(m, false));
        queueq;
        for (int i = 0; i< n; i++) {for (int j = 0; j< m; j++) {if (!mat[i][j]) {visited[i][j] = true;
                    q.push({i, j});
                }
            }
        }
        while (q.size()) {pii thisNode = q.front();
            q.pop();
            for (int d = 0; d< 4; d++) {int tx = thisNode.first + direcitons[d][0];
                int ty = thisNode.second + direcitons[d][1];
                if (tx >= 0 && tx< n && ty >= 0 && ty< m) {if (!visited[tx][ty]) {visited[tx][ty] = true;
                        mat[tx][ty] = mat[thisNode.first][thisNode.second] + 1;
                        q.push({tx, ty});
                    }
                }
            }
        }
        return mat;
    }
};

同步发文于,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/128175163

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧

标题名称:LeetCode0542.01矩阵-创新互联
URL地址:https://www.cdcxhl.com/article40/dspoeo.html

成都网站建设公司_创新互联,为您提供域名注册手机网站建设品牌网站建设网站建设网站维护企业网站制作

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都app开发公司