#include<stdio.h>
int n,m;
char field[1000][1000];
int dx,dy,nx,ny,res;
void dfs(int x,int y )
{
field[x][y]='.';
for(dx=-1;dx<=1;dx++)
{
for(dy=-1;dy<=1;dy++)
{
nx=dx+x;
ny=dy+y;
if(0<=nx&&nx<n&&0<=ny&&ny<m&&field[nx][ny]=='W')dfs(nx,ny);
}
}
}
int main()
{
int i,j;
scanf("%d%d",&n,&m);
for(i=0;i<n;i++)
{
getchar();
for(j=0;j<m;j++)
{
scanf("%c",&field[i][j]);
}
}
res=0;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
if(field[i][j]=='W')
{
dfs(i,j);
res++;
}
}
}
printf("%d\n",res);
return 0;
}
http://www.cnblogs.com/CSU3901130321/p/3991894.html
没有注释的代码不想看