NoiOpenJudge 2.5 紅與黑

總時間限制: 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;
   }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章