#include <iostream>
#include <cstring>
#include <cstdio>
#include <iostream>
#include <iomanip>
#include <string>
#include <cstring>
#include <cstdlib>
#include <typeinfo>
#include <sstream>
#include <iomanip>
#include <vector>
using namespace std;
const int maxn=100+10;
char s[maxn][maxn];
int n,m;
int num[9][2]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,0},{0,1},{1,-1},{1,0},{1,1}};
void dfs(int r,int c)
{ s[r][c]='*';
for(int i=0;i<9;i++)
{
int x=r+num[i][0];
int y=c+num[i][1];
if(x>=0&&x<n&&y>=0&&y<m&&s[x][y]=='@')
dfs(x,y);
}
}
int main()
{
while(scanf("%d%d",&n,&m)&&n&&m)
{int cnt=0;
for(int i=0;i<n;i++)
scanf("%s",s[i]);
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
if(s[i][j]=='@')
{
dfs(i,j);
cnt++;
}
printf("%d\n",cnt);
}
return 0;
}
#include <cstring>
#include <cstdio>
#include <iostream>
#include <iomanip>
#include <string>
#include <cstring>
#include <cstdlib>
#include <typeinfo>
#include <sstream>
#include <iomanip>
#include <vector>
using namespace std;
const int maxn=100+10;
char s[maxn][maxn];
int n,m;
int num[9][2]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,0},{0,1},{1,-1},{1,0},{1,1}};
void dfs(int r,int c)
{ s[r][c]='*';
for(int i=0;i<9;i++)
{
int x=r+num[i][0];
int y=c+num[i][1];
if(x>=0&&x<n&&y>=0&&y<m&&s[x][y]=='@')
dfs(x,y);
}
}
int main()
{
while(scanf("%d%d",&n,&m)&&n&&m)
{int cnt=0;
for(int i=0;i<n;i++)
scanf("%s",s[i]);
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
if(s[i][j]=='@')
{
dfs(i,j);
cnt++;
}
printf("%d\n",cnt);
}
return 0;
}
深度优先搜索算法实现
518

被折叠的 条评论
为什么被折叠?



