您的位置:首页 > 其它

hdu1241——Oil Deposits(DFS)

2016-08-01 10:33 399 查看
简单的DFS,省赛也有过类似的题

#include <iostream>
#include <cstring>
#include <string>
#include <vector>
#include <queue>
#include <cstdio>
#include <algorithm>
#define INF 0x3f3f3f3f
#define MAXN 100010
using namespace std;
int m,n,vis[105][105];
int dx[]={0,0,1,-1,1,-1,1,-1};
int dy[]={1,-1,0,0,1,1,-1,-1};
char mp[105][105];
void dfs(int x,int y)
{
if(x<0||x>=m||y<0||y>=n||vis[x][y]||mp[x][y]!='@')
return;
vis[x][y]=1;
for(int i=0;i<8;++i)
{
dfs(x+dx[i],y+dy[i]);
}
}
int main()
{
while(~scanf("%d%d",&m,&n))
{
if(m==0&&n==0)
break;
memset(vis,0,sizeof(vis));
for(int i=0;i<m;++i)
for(int j=0;j<n;++j)
cin>>mp[i][j];
int ans=0;
for(int i=0;i<m;++i)
for(int j=0;j<n;++j)
{
if(mp[i][j]=='@'&&!vis[i][j])
{
ans++;
dfs(i,j);
}
}
printf("%d\n",ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: