C++?LeetCode542矩陣示例詳解
LeetCode 542.01 矩陣
力扣題目鏈接:leetcode.cn/problems/01…
給定一個(gè)由 0 和 1 組成的矩陣 mat ,請(qǐng)輸出一個(gè)大小相同的矩陣,其中每一個(gè)格子是 mat 中對(duì)應(yīng)位置元素到最近的 0 的距離。
兩個(gè)相鄰元素間的距離為 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.lengthn == mat[i].length1 <= m, n <= 1041 <= m * n <= 104mat[i][j] is either 0 or 1.mat中至少有一個(gè)0
方法一:廣度優(yōu)先搜索
首先遍歷原始矩陣,找到所有的0,將其位置入隊(duì)。
接著在隊(duì)列不為空時(shí),不斷出隊(duì)一個(gè)位置,并判斷這個(gè)位置的上下左右是否被遍歷過(guò)。
如果還沒(méi)有被遍歷過(guò),那么就將新的位置入隊(duì)。并將地圖中新的位置的值修改為“出隊(duì)位置的值 + 1”
原理:
所有的原始的0最終結(jié)果都是0。廣度優(yōu)先搜索就是在所有的“0”的位置中,走一步。這一步所到的位置就是“1”步能到達(dá)的位置。同理,“1”經(jīng)過(guò)一步到達(dá)的位置就是“2”。最先到達(dá)的就是步數(shù)最少的。
- 時(shí)間復(fù)雜度O(nm)
- 空間復(fù)雜度O(nm)
AC代碼
C++
typedef pair<int, int> pii;
const int direcitons[4][2] = {{-1, 0}, {1, 0}, {0, 1}, {0, -1}};
class Solution {
public:
vector<vector<int>> updateMatrix(vector<vector<int>>& mat) {
int n = mat.size(), m = mat[0].size();
vector<vector<bool>> visited(n, vector<bool>(m, false));
queue<pii> q;
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;
}
};以上就是C++ LeetCode542矩陣示例詳解的詳細(xì)內(nèi)容,更多關(guān)于C++ LeetCode542矩陣的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- C++實(shí)現(xiàn)LeetCode(56.合并區(qū)間)
- Go/C語(yǔ)言LeetCode題解997找到小鎮(zhèn)法官
- C語(yǔ)言雙指針多方法旋轉(zhuǎn)數(shù)組解題LeetCode
- C語(yǔ)言動(dòng)態(tài)規(guī)劃點(diǎn)殺dp算法LeetCode炒股習(xí)題案例解析
- C/C++題解LeetCode1295統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字
- C/C++哈希表優(yōu)化LeetCode題解997找到小鎮(zhèn)的法官
- C++ LeetCode1796字符串中第二大數(shù)字
- C語(yǔ)言題解Leetcode56合并區(qū)間實(shí)例
相關(guān)文章
C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼
本文主要介紹C語(yǔ)言 選擇排序算法,這里對(duì)排序算法做了詳細(xì)說(shuō)明,并附代碼示例,有需要的小伙伴可以參考下2016-08-08
opencv實(shí)現(xiàn)角點(diǎn)檢測(cè)
這篇文章主要為大家詳細(xì)介紹了opencv實(shí)現(xiàn)角點(diǎn)檢測(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
C++讀入"N,X,Y,Z"格式文本文件到Eigen3 Matrix
這篇文章主要介紹了C++讀入"N,X,Y,Z"格式文本文件到Eigen3 Matrix,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
C++實(shí)現(xiàn)CreatThread函數(shù)主線程與工作線程交互的方法
這篇文章主要介紹了C++實(shí)現(xiàn)CreatThread函數(shù)主線程與工作線程交互的方法,是Windows應(yīng)用程序設(shè)計(jì)中非常實(shí)用的方法,需要的朋友可以參考下2014-10-10
NDK 數(shù)據(jù)結(jié)構(gòu)之隊(duì)列與棧等的實(shí)現(xiàn)
這篇文章主要介紹了NDK 數(shù)據(jù)結(jié)構(gòu)之隊(duì)列與棧等的實(shí)現(xiàn)的相關(guān)資料,希望通過(guò)本文大家能理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10
C++輸入一個(gè)字符串,把其中的字符按照逆序輸出的兩種方法解析
以下是對(duì)C++中輸入一個(gè)字符串,把其中的字符按照逆序輸出的兩種方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-07-07

