#include <bits/stdc++.h>
#include <cstdio>
using namespace std;
int n;
int x=0,y=0;
int a[35][35],b[35][35];
int xx[4]={1,-1,0,0};
int yy[4]={0,0,1,-1};
struct T
{
int x,y;
} c[1001];
void bfs(int x,int y)
{
int h=0,t=1;
int p,q;
c[1].x=x;
c[1].y=y;
b[x][y]=1;
a[x][y]=2;
do
{
h++;
for(int i=0;i<4;i++)
{
p=c[h].x+xx[i];
q=c[h].y+yy[i];
if(a[p][q]==1 || b[p][q] || p<0 || p>=n || q<0 || q>=n)
{
continue;
}
t++;
c[t].x=p;
c[t].y=q;
b[p][q]=1;
a[p][q]=2;
}
}while(h<t);
}
int main()
{
cin>>n;
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
cin>>a[i][j];
}
}
bool flag=false;
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(a[i][j]==1)
{
bfs(i+1,j+1);
flag=true;
break;
}
}
if(flag)
{
break;
}
}
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
cout<<a[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
P1162 填涂颜色
最新推荐文章于 2024-07-02 15:57:06 发布