Ai
1 Star 2 Fork 5

LilithSangreal/LeetCode-Solutions

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
walls-and-gates.cpp 1.02 KB
一键复制 编辑 原始数据 按行查看 历史
kamyu 提交于 2016-03-30 21:50 +08:00 . Update walls-and-gates.cpp
// Time: O(m * n)
// Space: O(g)
class Solution {
public:
void wallsAndGates(vector<vector<int>>& rooms) {
const int INF = numeric_limits<int>::max();
queue<pair<int, int>> q;
for (int i = 0; i < rooms.size(); ++i) {
for (int j = 0; j < rooms[0].size(); ++j) {
if (rooms[i][j] == 0) {
q.emplace(i, j);
}
}
}
while (!q.empty()) {
int i, j;
tie(i, j) = q.front();
q.pop();
for (const pair<int, int>& d :
vector<pair<int, int>>{{i + 1, j}, {i - 1, j},
{i, j + 1}, {i, j - 1}}) {
int I, J;
tie(I, J) = d;
if (I >= 0 && I < rooms.size() &&
J >= 0 && J < rooms[0].size() &&
rooms[I][J] == INF) {
rooms[I][J] = rooms[i][j] + 1;
q.emplace(I, J);
}
}
}
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/LilithSangreal/LeetCode-Solutions.git
git@gitee.com:LilithSangreal/LeetCode-Solutions.git
LilithSangreal
LeetCode-Solutions
LeetCode-Solutions
master

搜索帮助