1 1 * 3 5 *@*@* **@** *@*@* 1 8 @@****@* 5 5 ****@ *@@*@ *@**@ @@@*@ @@**@ 0 0
0 1 2 2
至于读者的你想用广搜还是深搜那就取决于您自己的风格了
我这里贴上我的广搜AC代码~
#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std;
struct zuobiao
{
int x,y;
}now,nex;
int fx[8]={-1,-1,0,1,1,1,0,-1};
int fy[8]={0,1,1,1,0,-1,-1,-1};
char a[110][110];
int vis[110][110];
int m,n;
int output;
void bfs(int x,int y)
{
if(vis[x][y]==0)output++;
vis[x][y]=1;
queue<zuobiao>s;
now.x=x;
now.y=y;
s.push(now);
while(!s.empty())
{
now=s.front();
s.pop();
for(int i=0;i<8;i++)
{
nex.x=now.x+fx[i];
nex.y=now.y+fy[i];
if(nex.x>=0&&nex.x<m&&nex.y>=0&&nex.y<n&&a[nex.x][nex.y]=='@'&&vis[nex.x][nex.y]==0)
{
vis[nex.x][nex.y]=1;
s.push(nex);
}
}
}
}
int main()
{
while(~scanf("%d%d",&m,&n))
{
if(m==0&&n==0)break;
output=0;
memset(vis,0,sizeof(vis));
memset(a,0,sizeof(a));
for(int i=0;i<m;i++)
{
scanf("%s",a[i]);
}
for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
if(a[i][j]=='@'&&vis[i][j]==0)
bfs(i,j);
}
}
printf("%d\n",output);
}
}