hdu-1241 Oil Deposits
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1241
简单的深搜,但是我花了两个小时都没没有做出来,说出来都是泪啊
代码:
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
char map[120][120];
int n,m;
int top[8][2]={{-1,0},{-1,-1},{-1,1},{0,1},{0,-1},{1,1},{1,0},{1,-1}};//八个点
void dfs(int a,int b){
int i;
map[a][b]='*';
for(i=0;i<8;i++){
int x=top[i][0]+a;
int y=top[i][1]+b;
if(x<0||x>=m||y<0||y>=n)
continue;
if(map[x][y]!='*')
dfs(x,y);
}
return;
}
int main(){
int i,j;
while(~scanf("%d%d",&m,&n),m!=0){
getchar();
for(i=0;i<m;i++)
{
scanf("%s",map[i]);
//getchar();
}
int ans=0;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
if(map[i][j]=='@')
{
//map[i][j]='#';
dfs(i,j);
ans++;
}
}
printf("%d\n",ans);
}
return 0;
}

浙公网安备 33010602011771号