nyist 82迷宫寻宝(一)(BFS)
题目连接:http://acm.nyist.net/JudgeOnline/problem.php?pid=82
此题在基础BFS上加入了门和钥匙,要找齐所有钥匙才能开门,所以要对门特殊处理。
1.先统计下各类钥匙的数量,再记下门的位置。
2.进行BFS,遇到钥匙时,入队,计数各类已找到的钥匙,然后判断是否钥匙找齐,如果找齐,找到对应的门,如果门之前是否访问过,则门入队。(可能此门被障碍堵住,无法进去,所以不能直接加入,只能以前访问过的加入)。
3.如果遇到门,判断钥匙是否找齐,若齐,入队,标记已访问;不齐,不入队,标记已访问。
4.其他的按正常的BFS即可。
#include <iostream>
#include <cstring>
#include <queue>
using namespace std;
struct point
{
int x,y;
}s,e,men[6];
int n,m;
int h[4][2]={-1,0,1,0,0,1,0,-1};
int yaosum[6],findyao[6],bz[30][30];
char map[30][30];
queue<point> q;
int bfs(point s)
{
int i; point temp,t;
while(!q.empty()) q.pop();
q.push(s); bz[s.x][s.y]=1;
while(!q.empty())
{
temp=q.front(); q.pop();
if(temp.x==e.x&&temp.y==e.y) return 1;
for(i=0;i<4;i++)
{
t.x=temp.x+h[i][0]; t.y=temp.y+h[i][1];
if(t.x>=0&&t.x<n&&t.y>=0&&t.y<m&&map[t.x][t.y]!='X')
{
if(map[t.x][t.y]>='A'&&map[t.x][t.y]<='E'&&!bz[t.x][t.y])//是门,看是否能打开
{
if(findyao[map[t.x][t.y]-'A']==yaosum[map[t.x][t.y]-'A'])//钥匙齐,可以打开
{
q.push(t); bz[t.x][t.y]=1;
}
else bz[t.x][t.y]=1; //无法打开,先标记已访问
}
else if(map[t.x][t.y]>='a'&&map[t.x][t.y]<='e'&&!bz[t.x][t.y]) //是钥匙
{
findyao[map[t.x][t.y]-'a']++;
q.push(t); bz[t.x][t.y]=1;
//判断钥匙是不是已经找齐,并且对应的门是否已访问过,若钥匙齐,门之前访问过,可以把门入队
if(findyao[map[t.x][t.y]-'a']==yaosum[map[t.x][t.y]-'a'])
{
point m; m.x=men[map[t.x][t.y]-'a'].x; m.y=men[map[t.x][t.y]-'a'].y;
if(bz[m.x][m.y]) q.push(m); //门入队
}
}
else if((map[t.x][t.y]=='.'||map[t.x][t.y]=='G')&&!bz[t.x][t.y])
{
q.push(t); bz[t.x][t.y]=1;
}
}
}
}
return 0;
}
int main(int argc, char *argv[])
{
int i,j;
while(cin>>n>>m&&(n+m))
{
memset(yaosum,0,sizeof(yaosum));
memset(findyao,0,sizeof(findyao));
memset(bz,0,sizeof(bz));
for(i=0;i<n;i++)
for(j=0;j<m;j++)
{
cin>>map[i][j];
if(map[i][j]=='S') {s.x=i;s.y=j;}
else if(map[i][j]=='G') {e.x=i; e.y=j;}
else if(map[i][j]>='a'&&map[i][j]<='e') yaosum[map[i][j]-'a']++;
else if(map[i][j]>='A'&&map[i][j]<='E')
{
men[map[i][j]-'A'].x=i; men[map[i][j]-'A'].y=j;
}
}
if(bfs(s)) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
return 0;
}
nyist 82迷宫寻宝(一)(BFS)的更多相关文章
- nyoj 82 迷宫寻宝(一)
点击打开链接 迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个很特别的迷宫,迷宫 ...
- Problem 2285 迷宫寻宝 (BFS)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2285 Problem 2285 迷宫寻宝 Accept: 323 Submit: 1247Time Li ...
- nyoj 82 迷宫寻宝(二)
http://acm.nyist.net/JudgeOnline/problem.php?pid=83 题目解法主要在于判断两线段是否相交,思路是穷举所有地图四周的点,其中每一个边界上的点和终点构成一 ...
- 迷宫寻宝(一)(bfs)
迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个很特别的迷宫,迷宫里有N个编 ...
- NYOJ82 迷宫寻宝(一)【BFS】
迷宫寻宝(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描写叙述 一个叫ACM的寻宝者找到了一个藏宝图.它依据藏宝图找到了一个迷宫,这是一个非常特别的迷宫,迷宫里有N个 ...
- 福州大学第十五届程序设计竞赛_重现赛B题迷宫寻宝
Problem B 迷宫寻宝 Accept: 52 Submit: 183Time Limit: 1000 mSec Memory Limit : 32768 KB Problem De ...
- Unity3D实现立体迷宫寻宝
Unity3D实现立体迷宫寻宝 这个小游戏是一个白痴在一个昏暗的房间走动找到关键得分点,然后通关游戏.入门Unity3D做的第一款游戏,比较无聊,但实现了一般的游戏功能.如,人物控制,碰撞检测,主控制 ...
- POJ.3894 迷宫问题 (BFS+记录路径)
POJ.3894 迷宫问题 (BFS+记录路径) 题意分析 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, ...
- Problem 2285 迷宫寻宝
http://acm.fzu.edu.cn/problem.php?pid=2285 Problem Description 洪尼玛今天准备去寻宝,在一个n*n (n行, n列)的迷宫中,存在着一个入 ...
随机推荐
- SharePoint 要一个多行文本类型字段为特殊类型的链接
1.插入在测试列表中的多行文本字段.名字叫做Content.例如下面的附图: 2.在Content字段里.加入一个Link.例如以下图: 3.尝试输入Notes格式的Link,例如以下图: 4.点击O ...
- Unity用户自定义圆角头像
前天朋友遇到一个这样的需求,而且比较棘手让我帮忙解决.需求就是棋牌类的游戏,玩家的个人资料中包括自己的头像而且可以浏览相册中的图片或者使用相机拍照设置.关于这个问题我也查阅一些资料,由于涉及安卓部分知 ...
- Spring简单的小例子SpringDemo,用于初略理解什么是Spring以及JavaBean的一些概念
一.开发前的准备 两个开发包spring-framework-3.1.1.RELEASE-with-docs.zip和commons-logging-1.2-bin.zip,将它们解压,然后把Spri ...
- jQuery中DOM操作
1 定义:jquery中对DOM的操作就是对DOM元素进行增删查改操作 2 分类: 1)DOM Core(核心):用途广泛 支持多种编程语言 2)HTML DOM:代码简短 只用于处理web ...
- 转载——CLR标量函数、表值函数和聚合函数(UDA)
本节主要介绍使用CLR创建标量函数,表值函数和聚合函数. 所谓标量函数指的就是此函数只返回一个值.表值函数返回值是一个表.聚合函数是在select语句中使用的,用来聚合一个结果集,类似于Sum()或是 ...
- php多文本框提交
<form action="" method="post"><input type=text name=name[]><input ...
- 练习使用css3实现3d按钮
网上有很多漂亮的用css3实现的3d按钮,如'这个'.‘糖果色按钮’, 今天练习了一下,喏,下面这样,兼容性不好. 小黑子小虎子 3d效果和发光效果都是利用box-shadow,也经常利用伪元素:af ...
- js图片实时加载
浏览大型网站,特别是图片比较多的图片,如大型的电商网站,你会发现处了第一屏外,往下滚动的时候图片才加载出来,没必要一开始加载就要把全部图片加载出来,这样子打开网面的速度得到了很好提高.以下是笔者目前所 ...
- HTML5比较实用的代码
增强IE兼容性 <!--[if IE]> <script src="http://html5shim.googlecode.com/svn/trunk/html5.js&q ...
- Regular expression cheat sheet
\s white-space characters \S Non-white-space characters \d digital numbers \D non-digital numbers \w ...