传送门:https://vjudge.net/problem/UVA-572
具体原题看链接。
大意:输入一个m行n列字符矩阵,统计字符@组成多少个八连块(如果两个字符@所在格子横竖对角线方向相邻就是八连块)。
简单的DFS遍历,适合入门,我把代码能打的注释尽量都打了
#include<cstdio>
#include<cstring>
const int maxn=100+5;
char pic[maxn][maxn];//存储输入的字符矩阵
int m,n,idx[maxn][maxn];//m行n列,连通分量编号
void dfs(int r,int c,int id)
{
if(r<0||r>=m||c<0||c>=n)
return;//出界的格子返回
if(idx[r][c]>0||pic[r][c]!='@')
return;//不是@的或者访问过的格子
idx[r][c]=id;//连通分量编号
for(int dr=-1;dr<=1;dr++)
for(int dc=-1;dc<=1;dc++)//方向
if(dr!=0||dc!=0)
dfs(r+dr,c+dc,id);//向八个方向递归搜索结果是把开始访问的点和他周边是@的地方都记录了连通分量编号
}
int main()
{
while(scanf("%d%d",&m,&n)==2&&m&&n)
{
for(int i=0;i<m;i++)
scanf("%s",pic[i]);
memset(idx,0,sizeof(idx));//memset()针对字节操作这是将一个数组的所有分量设为0的便捷方法
int cnt=0;
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
if(idx[i][j]==0&&pic[i][j]=='@')//从没被搜索并且是@的地方开始深搜
dfs(i,j,++cnt);
printf("%d\n",cnt);
}
return 0;
}