题目描述
Farmer John一直努力让他的草地充满鲜美多汁的而又健康的牧草。
可惜天不从人愿,他在植物大战人类中败下阵来。邪恶的乳草已经
在他的农场的西北部份占领了一片立足之地。草地像往常一样,被
分割成一个高度为Y(1 <= y <= 100),
宽度为X(1 <= x <= 100)的直角网格。(1,1)是左下角的格(也就
是说坐标排布跟一般的X,Y坐标相同)。乳草一开始占领了格(Mx,My)。
每个星期,乳草传播到已被乳草占领的格子四面八方的每一个没有
很多石头的格(包括垂直与水平相邻的和对角线相邻的格)。1周之
后,这些新占领的格又可以把乳草传播到更多的格里面了。 Bessie
想要在草地被乳草完全占领之前尽可能的享用所有的牧草。她很好奇
到底乳草要多久才能占领整个草地。如果乳草在0时刻处于格(Mx,My),
那么还在那个时刻它们可以完全占领入侵整片草地呢(对给定的数
据总是会发生)?草地由一个图片表示。"."表示草,而"*"表示大石
。比如这个X=4, Y=3的例子。
....
..*.
.**.
如果乳草一开始在左下角(第1排,第1列),那么草地的地图将会以
如下态势发展:
.... .... MMM. MMMM MMMM
..*. MM*. MM*. MM*M MM*M
M**. M**. M**. M**. M**M
星期数 0 1 2 3 4
乳草会在4星期后占领整片土地。
输入
* 第一行: 四个由空格隔开的整数: X, Y, Mx, My
* 第2到第Y+1行: 数据的第y+1行由X个字符("."表示草地,"*"表示大石),描述草地的第(Y+2-y)行。
输出
* 第一行: 一个单独的整数表示最后一个不是大石块的格子被乳草占领的星期数。
样例输入
4 3 1 1
....
..*.
.**.
样例输出
4
来源
USACO 2009 October Silver
满分代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <algorithm>
#include <string>
using namespace std;
struct node
{
int x,y,step;
};
char map[205][205];
int n,m;
int dx[]= {-1,-1,-1,0,0,1,1,1};
int dy[]= {-1,0,1,-1,1,-1,0,1};
bool visit[205][205];
int ans;
void bfs(node s)
{
queue <node> Q;
node now,next;
Q.push(s);
visit[s.x][s.y]=1;
while(!Q.empty())
{
now=Q.front();
Q.pop();
//printf("%d %d %d\n",now.x,now.y,now.step);
for(int i=0; i<8; i++)
{
next=now;
next.x=now.x+dx[i];
next.y=now.y+dy[i];
if(next.x>=0&&next.x<m&&next.y>=0&&next.y<n&&!visit[next.x][next.y]&&map[next.x][next.y]!='*')
{
next.step=now.step+1;
Q.push(next);
visit[next.x][next.y]=1;
if(ans<next.step) ans=next.step;
}
}
}
printf("%d",ans);
return ;
}
int main()
{
memset(visit,0,sizeof(visit));
node s;
//freopen("1030.in","r",stdin);
//freopen("1030.out","w",stdout);
scanf("%d %d %d %d",&n,&m,&s.y,&s.x);
s.x--,s.y--;
s.step=0;
ans=0;
for(int i=m-1; i>=0; i--)
scanf("%s",map[i]);
for(int i=0; i<m; i++)
for(int j=0; j<n; j++)
if(map[i][j]=='*') visit[i][j]=1;
//for(int i=0;i<m;i++) printf("%s",map[i]);
bfs(s);
return 0;
}
jzxx1589乳草的入侵
最新推荐文章于 2022-05-03 11:01:37 发布