程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> BNUOJ 1038 Flowers(BFS)

BNUOJ 1038 Flowers(BFS)

編輯:關於C++

Flowers

Time Limit: 1000ms Memory Limit: 65535KB 64-bit integer IO format: %lld Java class name: Main Prev Submit Status Statistics Discuss Next 春天到了,師大的園丁們又開始忙碌起來了.

京師廣場上有一塊空地,邊界圍成了一個多邊形,內部被劃分成一格一格的.園丁們想在這個多邊形內的每一格內種植一些花.

現在請你幫忙計算一下一共最多可以種多少花.

廣場用一個M*N的字符數組表示,.和*代表一個方格,其中*代表空地的邊界,.是空格,只有邊界內部的空格才能用於種花.
一個空格位於邊界內部,當且僅當由該點出發只允許向上、下、左、右四個方向移動,最終都會遇到邊界。


例如下面就是一個6*7的廣場

.......
..***..
..*..*.
..*..*.
...**..
.......

種花方案如下(數字代表的地方)
.......
..***..
..*12*.
..*34*.
...**..
.......

Input

輸入數據第一行是M和N(M和N不超過100),代表有廣場的大小
接下來就是一個M*N的字符矩陣,是廣場的表示

Output

對應於輸入數據,輸出一個整數,給出輸入的情形能夠種的花數目.

Sample Input

Sample Input1
6 7
.......
..***..
..*..*.
..*..*.
...**..
.......
Sample Input2
5 7
.......
..***..
..*.*..
..***..
.......

Sample Output

Sample Output1
4
Sample Output2
1

Source

第七屆北京師范大學程序設計競賽熱身賽第四場
#include
#include
#include
using namespace std;
const int N = 105 ;
struct node
{
    int x,y;
};
char mapt[N][N];
int vist[N][N],n,m;
int dir[4][2]={0,1,0,-1,1,0,-1,0};

int bfs(int x,int y)
{
    queueq;
    node now,pre;
    int ans=1,flag=1;
    vist[x][y]=1;
    now.x=x; now.y=y;
    q.push(now);
    while(!q.empty())
    {
        pre=q.front(); q.pop();
        for(int e=0; e<4; e++)
        {
            now.x=pre.x+dir[e][0];
            now.y=pre.y+dir[e][1];
            if(now.x<0||now.x>=n||now.y<0||now.y>=m)
            {
                flag=0; continue;
            }
            if(!vist[now.x][now.y]&&mapt[now.x][now.y]=='.')
            {
                vist[now.x][now.y]=1;
                ans++;
                q.push(now);
            }
        }
    }
    if(flag==0) ans=0;
    return ans;
}
int main()
{
    //int n,m;
    while(scanf(%d%d,&n,&m)>0)
    {
        for(int i=0; i

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved