天天看點

矩陣距離(多源bfs)

題目:

#include <bits/stdc++.h>
using namespace std;
int n,m;
char pos[1005][1005];
int dis[1005][1005];
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
typedef pair<int,int> pll;
void bfs()
{
    memset(dis,-1,sizeof dis);
    queue<pll> q;
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<m;j++)
        {
            if(pos[i][j]=='1')
            {
                dis[i][j]=0;
                q.push({i,j});
            }
        }
    }
    while(!q.empty())
    {
        pll k=q.front();
        q.pop();
        int x=k.first,y=k.second;
        for(int i=0;i<4;i++)
        {
            int nx=x+dx[i],ny=y+dy[i];
            if(nx<0||nx>=n||ny<0||ny>=m||dis[nx][ny]!=-1) continue;
            dis[nx][ny]=dis[x][y]+1;
            q.push({nx,ny});
        }
    }
}
int main()
{
    cin>>n>>m;
    for(int i=0;i<n;i++) cin>>pos[i];
    bfs();
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<m;j++)
        {
            cout<<dis[i][j]<<" ";
        }
        cout<<endl;
    }
    return 0;
}      

繼續閱讀