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列)的迷宫中,存在着一个入 ...
随机推荐
- UDP C/S编程
UDP C/S编程的步骤如下图所示与TCP C/S通信的区别在于:服务端没有设置监听和等待连接的过程.客户端没有连接服务端的过程.基于UDP的通信时不可靠地,面向无连接的,发送的数据无法确切知道对方收 ...
- Python的学习
1.psutil的安装 [root@YQY-TIAN- ~]# wget https://pypi.python.org/packages/source/p/psutil/psutil-2.0.0.t ...
- thinkphp 中 使用七牛云上传
利用七牛云私有空间存储文件 第一步,注册七牛云,创建空间,将空间设为私有 需要记下的东西: AK,SK,bucket 第二步配置ThinkPHP 在config.php添加 'UPLOAD_SITEI ...
- html 文字溢出标签
overflow:visible;作用:能看到溢出部分. overflow: hidden;作用:溢出部分看不到 overflow:scroll; 作用:出现一个滚动条(不超过的文字也会在滚动条里) ...
- a标签调用js的几种方法
我们常用的在a标签中有点击事件: <a> 标签的 href 属性用于指定超链接目标的 URL,href 属性的值可以是任何有效文档的相对或绝对 URL,包括片段标识符和 JavaScrip ...
- UI基础视图----UIView总结
UIView是UIKit框架里面最基础的视图类,是UIResponder的子类,是UIApplication和UIViewController的兄弟类,是UIWindow,UILabel,UIImag ...
- js动态加载html,加载后的页面元素某些事件失效的解决方案
用 live 来绑定 例如: $("#items li .addToCartimg").live("click",function(){ $('.popDeta ...
- ZOJ 1633
迭代 每个数对应前面的一个数 #include<stdio.h> #include<iostream> using namespace std; #define max 88 ...
- 自适应 or 移动前端页面布局的问题?
说出来,还请各位看官不要笑 - -.哥们至今不是很清楚页面的自适应和移动前端页面开发有什么区别 .有幸哪位看官清楚这些的话,希望能不吝赐教 .A.meta <meta name=& ...
- ubuntu 14.04解决gedit中文乱码的问题
终端输入 gsettings set org.gnome.gedit.preferences.encodings auto-detected "['UTF-8','GB18030','GB2 ...