POJ 1979 Red and Black【DFS】
标准DFS,统计遍历过程中遇到的黑点个数
#include<cstdio> #include<vector> #include<queue> #include<string> #include<map> #include<iostream> #include<cstring> #include<algorithm> using namespace std; typedef long long LL; const int INF = 0x7FFFFFFF; const int maxn = 1e5 + 10; int w,h,x,y; int visit[20][20],ans=0; char m[20][20]; int dir[4][2]={1,0,-1,0,0,1,0,-1}; void dfs(int x,int y) { visit[x][y]=1; ans++; for(int i=0;i<4;i++) { int nx=x+dir[i][0]; int ny=y+dir[i][1]; if(nx>=0&&nx<h&&ny>=0&&ny<w&&m[nx][ny]=='.'&&!visit[nx][ny]) dfs(nx,ny); } } int main() { while(cin>>w>>h&&w&&h) { for(int i=0;i<h;i++) for(int j=0;j<w;j++) { cin>>m[i][j]; if(m[i][j]=='@') x=i,y=j; } memset(visit,0,sizeof(visit)); ans=0; dfs(x,y); cout<<ans<<endl; } return 0; }