DFS入门精讲:油田(Oil Deposits UVA572)

传送门: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;
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值