1 #include <iostream> 2 #include <cstdio> 3 using namespace std; 4 5 const int MAX=105; 6 7 bool vis[MAX][MAX]; 8 char maze[MAX][MAX]; 9 int n,m; 10 int dir[8][2]={0,1,1,0,0,-1,-1,0,1,1,1,-1,-1,1,-1,-1}; 11 12 bool ok(int i,int j){ 13 if(!vis[i][j]&&maze[i][j]==‘@‘&&i>=0&&i<n&&j>=0&&j<m) 14 return true; 15 return false; 16 } 17 18 void dfs(int i,int j){ 19 int ti,tj; 20 for(int k=0;k<8;k++){ 21 ti=i+dir[k][0]; 22 tj=j+dir[k][1]; 23 if(ok(ti,tj)){ 24 vis[ti][tj]=true; 25 dfs(ti,tj); 26 } 27 } 28 } 29 30 int main(){ 31 while(scanf("%d%d",&n,&m)!=EOF){ 32 if(n==0) break; 33 for(int i=0;i<n;i++) 34 scanf("%s",maze[i]); 35 memset(vis,false,sizeof(vis)); 36 int ans=0; 37 for(int i=0;i<n;i++){ 38 for(int j=0;j<m;j++) 39 if(maze[i][j]==‘@‘&&!vis[i][j]){ 40 ans++; 41 dfs(i,j); 42 } 43 } 44 printf("%d\n",ans); 45 } 46 return 0; 47 }
原文:http://www.cnblogs.com/jie-dcai/p/3795595.html