题意:从’@‘开始找上下左右相邻的’.’的个数。
#include<stdio.h>
const int N = 22;
char c[N][N];
int m,n,ans;
int px[4]= {1,-1,0,0};
int py[4]= {0,0,1,-1};
void dfs(int x,int y) {
c[x][y]='#';
ans++;
for(int l=0; l<4; l++) {
int nx=x+px[l];
int ny=y+py[l];
if(c[nx][ny]=='.'&&nx<n&&ny<m&&nx>=0&&ny>=0) {
dfs(nx,ny);
}
}
}
int main() {
while(scanf("%d%d",&m,&n),m||n) {
int x,y;
for(int l=0; l<n; l++)
scanf("%s",c[l]);
for(int i=0; i<n; i++)
for(int j=0; j<m; j++) {
if(c[i][j]=='@')
x=i,y=j;
}
ans=0;
dfs(x,y);
printf("%d\n",ans);
}
return 0;
}