题解
2025-08-03 23:26:24
发布于:广东
5阅读
0回复
0点赞
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e2+5;
int n,m,cnt;
char s[maxn][maxn];
int vis[maxn][maxn];
void dfs(int x,int y)
{
vis[x][y]=cnt;
for(int i=-1;i<=1;i++)
{
for(int j=-1;j<=1;j++)
{
int nx=x+i,ny=y+j;
if(nx>=1&&nx<=n&&ny>=1&&ny<=m&&s[nx][ny]=='W'&&!vis[nx][ny])
{
dfs(nx,ny);
}
}
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>s[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(s[i][j]=='W'&&!vis[i][j])
{
cnt++;
dfs(i,j);
}
}
}
cout<<cnt;
return 0;
}
这里空空如也
有帮助,赞一个