int orangesRotting(vector<vector<int>>& grid) {
int dx[4] = {1, 0, 0, -1};
int dy[4] = {0, 1, -1, 0};
int time[15][15];
queue<pair<int,int>> q;
int n=grid.size();
int m=grid[0].size();
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
if(grid[i][j]==0){
time[i][j]=-1;
}else{
time[i][j]=0;
if(grid[i][j]==2){
q.push({i,j});
}
}
}
}
while(!q.empty()){
int x=q.front().first;
int y=q.front().second;
q.pop();
for(int i=0;i<4;i++){
int nx=x+dx[i];
int ny=y+dy[i];
if(nx>=0&&nx<n&&ny>=0&&ny<m&&grid[nx][ny]==1){
cout<<nx<<" "<<ny<<endl;
time[nx][ny]=time[x][y]+1;
grid[nx][ny]=2;
q.push({nx,ny});
}
}
}
int ans=0;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
if(grid[i][j]==1){
return -1;
}
ans=max(ans,time[i][j]);
}
}
return ans;
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律