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;
}

你可能感兴趣的:(hdu-1241 Oil Deposits)