一、题目分析
1.1题目
1.2输入输出案例
题解——多源BFS和最短路径
以原矩阵中的每个2为中心向外扩张,每扩张一次即过去1s。
再遍历一遍矩阵判断是否有没有腐蚀到的苹果。
**注意:**当扩张完全时,还会额外扩张一次,以判断是否已经扩张完。所以返回值需要 减一。
二、代码实现
class Solution
{
int m,n;
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
bool vis[1010][1010]={0};
public:
int rotApple(vector<vector<int>>& grid){
m=grid.size();
n=grid[0].size();
queue<pair<int,int>> q;
for(int i=0;i<m;++i){
for(int j=0;j<n;++j){
if(grid[i][j]==2)
q.push({i,j});
}
}
int ret=0;
while(!q.empty()){
int sz=q.size();
ret++;
while(sz--){
auto [a,b]=q.front();
q.pop();
for(int i=0;i<4;++i){
int x=a+dx[i],y=b+dy[i];
if(x>=0&& x<m && y>=0 && y<n&& grid[x][y]==1 &&!vis[x][y]){
vis[x][y]=true;
q.push({x,y});
}
}
}
}
for(int i=0;i<m;++i){
for(int j=0;j<n;++j){
if(grid[i][j]==1&&!vis[i][j])
return -1;
}
}
return ret-1;
}
};