DFS
题目大致意思是:
在一个矩阵map[ h ][ w ]中,阵中每一个格子不是红色就是黑色,红色的才可以到达,黑色的无法通过。一个人在map[ i ][ j ]位置上,根据测试数据中道路的分配,求出这个人能走过多少格子(包括他自己的起点)。
“ . ” 代表红色格子
“ # ” 代表黑色格子
“ @ ” 代表那个人的目前所在位置(只在图中出现一个)
本题的思路就是用DFS算法,即深度优先搜索。
1.申请一个二维字符型数组map来记录位置,一个二维整形数组flag来记录是否走过所在位置,若走过,则赋值为1 。
2.在dfs中,应从第1格开始搜索,即dfs(1,1)。这样得出的结果将不会错过每一个格子。
3.对于第i行,第j列的位置,即map[ i ][ j ],应对它的上下左右四个方位都进行搜索。如果搜索结果是红色并且还没有走过,则计数器+1,将flag数组赋值为1,再递归dfs函数继续。
AC代码如下:
#include <stdio.h>
#include <string.h>
char map[21][21];
int flag[21][21];
int h,w,step;
void DFS(int i,int j)
{
if(map[i-1][j]=='.' && flag[i-1][j]==0)
{
step++;
flag[i-1][j]=1;
DFS(i-1,j);
}
if(map[i+1][j]=='.' && flag[i+1][j]==0)
{
step++;
flag[i+1][j]=1;
DFS(i+1,j);
}
if(map[i][j-1]=='.' && flag[i][j-1]==0)
{
step++;
flag[i][j-1]=1;
DFS(i,j-1);
}
if(map[i][j+1]=='.' && flag[i][j+1]==0)
{
step++;
flag[i][j+1]=1;
DFS(i,j+1);
}
}
int main()
{
int i,j;
while(scanf("%d%d",&h,&w)!=EOF)
{
if(h==0 && w==0)
{
break;
}
step=0;
getchar();
memset(map,'#',sizeof(map));
memset(flag,0,sizeof(flag));
for(i=1;i<=w;i++)
{
for(j=1;j<=h;j++)
{
scanf("%c",&map[i][j]);
}
getchar();
}
for(i=1;i<=w;i++)
for(j=1;j<=h;j++)
{
if(map[i][j]=='@')
{
step++;
flag[i][j]=1;
DFS(i,j);
i=w;
j=h;
}
}
printf("%d\n",step);
}
return 0;
}