代码:
#include<iostream>
using namespace std;
char a[200][200];
int fx[4]={0,1,0,-1};
int fy[4]={1,0,-1,0};
int k=0;
int n,m;
void dfs(int x,int y){
a[x][y]='.';
int tx,ty;
for(int i=0;i<4;i++){
tx=x+fx[i];
ty=y+fy[i];
if(tx>=1&&tx<=n&&ty>=1&&ty<=m&&a[tx][ty]=='W'){
dfs(tx,ty);
}
}
}
int main(){
cin>>n>>m;
dfs(1,1);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(a[i][j]=='W'){
k++;
dfs(i,j);
}
}
}
cout<<k;
return 0;
}