總時間限制: 1000ms 內存限制: 65536kB
描述
有一間長方形的房子,地上鋪了紅色、黑色兩種顏色的正方形瓷磚。你站在其中一塊黑色的瓷磚上,只能向相鄰的黑色瓷磚移動。請寫一個程序,計算你總共能夠到達多少塊黑色的瓷磚。
輸入
包括多個數據集合。每個數據集合的第一行是兩個整數W和H,分別表示x方向和y方向瓷磚的數量。W和H都不超過20。在接下來的H行中,每行包括W個字符。每個字符表示一塊瓷磚的顏色,規則如下
1)‘.’:黑色的瓷磚;
2)‘#’:白色的瓷磚;
3)‘@’:黑色的瓷磚,並且你站在這塊瓷磚上。該字符在每個數據集合中唯一出現一次。
當在一行中讀入的是兩個零時,表示輸入結束。
輸出
對每個數據集合,分別輸出一行,顯示你從初始位置出發能到達的瓷磚數(記數時包括初始位置的瓷磚)。
#include <iostream>
#include <memory.h>
using namespace std;
int dx[4]={0,0,1,-1},dy[4]={1,-1,0,0},a[1005][1005],used[1005][1005],n,m,s;
void dfs(int x,int y)
{
int i,tx,ty;
for(i=0;i<=3;i++)
{
tx=x+dx[i];
ty=y+dy[i];
if(tx>0&&tx<=n&&ty>0&&ty<=m&&a[tx][ty]==0&&used[tx][ty]==0)
{
used[tx][ty]=1;
s++;
dfs(tx,ty);
}
}
}
int main()
{
int i,j,k,x,y;
char c;
cin>>m>>n;
while(n!=0&&m!=0)
{
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
{
cin>>c;
if(c=='.')
{
a[i][j]=0;
used[i][j]=0;
}
else if (c=='#')
a[i][j]=1;
else if (c=='@')
{
x=i;
y=j;
a[i][j]=0;
}
}
s=1;
used[x][y]=1;
dfs(x,y);
cout<<s<<endl;
cin>>m>>n;
}
}