算法叙述:DFS
从任意的w开始,不停的把邻接的部分用.来替代,一次DFS后与初始这个w相连接的所有w就都被替换成.,知道图中不在存在w为止,总共进行的DFS次数就是答案了。
我的代码:
#include<iostream>
using namespace std;
char a[110][110]={'\0'};
int N,M;
void DFS(int i,int j)
{
int ii,jj;
a[i][j]='.';
for(ii=-1;ii<=1;ii++)
{
for(jj=-1;jj<=1;jj++)
{
if((i+ii)>=0&&(i+ii)<N&&(j+jj)>=0&&(j+jj)<M&&a[i+ii][j+jj]=='W')
{
DFS(i+ii,j+jj);
}
}
}
return ;
}
int main()
{
int i,j,counter=0;
while(cin>>N>>M)
{
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
cin>>a[i][j];
}
}
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
if(a[i][j]=='W')
{
DFS(i,j);
counter++;
}
}
}
cout<<counter<<endl;
counter=0;
}
return 0;
}