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列)的迷宫中,存在着一个入 ...
随机推荐
- HDU 蟠桃记
蟠桃记 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submissio ...
- Java中的线程Thread总结
首先来看一张图,下面这张图很清晰的说明了线程的状态与Thread中的各个方法之间的关系,很经典的! 在Java中创建线程有两种方法:使用Thread类和使用Runnable接口. 要注意的是Threa ...
- UVA 10651 Pebble Solitaire(bfs + 哈希判重(记忆化搜索?))
Problem A Pebble Solitaire Input: standard input Output: standard output Time Limit: 1 second Pebble ...
- CareerCup Chapter 9 Sorting and Searching
9.1 You are given two sorted arrays, A and B, and A has a large enough buffer at the end to hold B. ...
- android学习——GestureDetector.OnGestureListener 详解
Android Touch Screen 与传统Click Touch Screen不同,会有一些手势(Gesture),例如Fling,Scroll等等.这些Gesture会使用户体验大大提升.An ...
- rhel Linux系统yum的配置
yum是一个很方便的linux系统软件管理工具,但是很多新手还是不会配置yum,下面详细的介绍下yum的配置方法,其实很简单. 1.首先确保系统ISO镜像已经成功挂载,可以用df -h命令查看.2.创 ...
- c - 冒泡/选择排序.
#include <stdio.h> #define LEN 10 #define TRUE 1 #define FALSE 0 /* 对 10 个数进行排序 */ //选择排序法(值得注 ...
- SQL自连接(源于推荐算法中的反查表问题)
”基于用户的协同过滤算法“是推荐算法的一种,这类算法强调的是:把和你有相似爱好的其他的用户的物品推荐给你. 要实现该推荐算法,就需要计算和你有交集的用户,这就要用到物品到用户的反查表. 先举个例子说明 ...
- FileStream 操作文件复制
static void Main(string[] args) { string source = @"D:\c\集合.avi"; string target = @"C ...
- (转)OS X 升級後 MacPorts 重新安裝筆記
原地址:http://blog.lyhdev.com/2012/07/os-x-macports.html Mac OS X 10.8 Mountain Lion 正式發佈,而且祭出台幣 $590 元 ...