jzxx1589乳草的入侵

题目描述
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;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值