CDOJ_149 解救小Q
原题网址:http://acm.uestc.edu.cn/#/problem/show/149
小Q被邪恶的大魔王困在了迷宫里,love8909决定去解救她。 迷宫里面有一些陷阱,一旦走到陷阱里,就会被困身亡:(,迷宫 里还有一些古老的传送
阵,一旦走到传送阵上,会强制被传送到 传送阵的另一头。
现在请你帮助love8909算一算,他至少需要走多少步才能解 救到小Q?
Input
第一行为一个整数T,表示测试数据组数。
每组测试数据第一行为两个整数N,M,(1≤N,M≤50)表示
迷宫的长和宽。
接下来有N行,每行M个字符,是迷宫的具体描述。
.
表示安全的位置#
表示陷阱,Q
表示小Q的位置L
表示love8909所在位置,
数据保证love8909只有一个,数据也保证小Q只有一个。
小写字母a
-z
表示分别表示不同的传送阵,数据保证传送阵
两两配对。
Output
每组数据输出一行,解救小Q所需的最少步数,如果无论如何都 无法救小Q,输出-1
。
Sample input and output
Sample Input | Sample Output |
---|---|
2 5 5 |
3 |
这道题采用广度优先搜索,每走过一个地方计算这个地方离起点的距离,并将这个点加入队列。不过要注意的是对应传送门的深度是相同的。为方便
#include<iostream>
#include<queue>
#include<string.h>
#define MAX_N 50
#define MAX_M 50
#define INF 3000
using namespace std; typedef pair<int, int> P;
char maze[MAX_N + 5][MAX_M + 5];//迷宫
int d[MAX_N + 5][MAX_M + 5];//表示离起点的距离
int dx[4] = { 0, 1, 0, -1 };
int dy[4] = { 1, 0, -1, 0 };
P door[MAX_N + 5][MAX_M + 5];//储存传送门的对应关系
bool flag[MAX_N + 5][MAX_M + 5];//记录节点是否被访问过
int lx, ly, qx, qy;
int N, M; void input()
{
P temp[28];
cin >> N >> M;
fill(temp, temp + 28, P(INF, INF));
for (int i = 0; i < N; i++)
for (int j = 0; j < M; j++)
door[i][j].first = door[i][j].second = INF;
for (int i = 0; i < N; i++)
for (int j = 0; j < M; j++)
{
char m;
cin >> m;
maze[i][j] = m;
if (m >= 'a' && m <= 'z')
{
if (temp[m - 'a'] == P(INF, INF))//传送门第一次出现
temp[m - 'a'] = P(i, j);
else//传送门已经出现过了
{
door[i][j] = P(temp[m - 'a'].first, temp[m - 'a'].second);
door[temp[m - 'a'].first][temp[m - 'a'].second] = P(i, j);
}
}
else if (m == 'L'){lx = i; ly = j; maze[i][j] = '#';}
else if (m == 'Q'){ qx = i; qy = j; }
}
} int bfs()
{
memset(flag, 0, sizeof(flag));
for (int i = 0; i < N; i++)
for (int j = 0; j < M; j++)
d[i][j] = INF;
queue<P> que;
que.push(P(lx, ly));//将起点加入队列
d[lx][ly] = 0;//并将起点的距离赋为0
while (!que.empty())//不断循环,知道队列为空
{
int nx, ny;
P now = que.front();//当前节点
que.pop();
if (now.first == qx&&now.second == qy)
break;
for (int i = 0; i < 4; i++)//向四个方向遍历
{
nx = now.first + dx[i];
ny = now.second + dy[i];
if (nx < N && nx >= 0 && ny < M && ny >= 0 && !flag[nx][ny])//未超边界,且未访问过
{
if (maze[nx][ny] <= 'z'&&maze[nx][ny] >= 'a')//传送门
{
int dnow = d[now.first][now.second];
d[door[nx][ny].first][door[nx][ny].second] = dnow + 1;//传送
que.push(P(door[nx][ny].first, door[nx][ny].second));//将传送后的节点加入队列
}
else if (maze[nx][ny] != '#')//不是传送门
{
d[nx][ny] = d[now.first][now.second] + 1;
que.push(P(nx, ny));
}
flag[nx][ny] = 1;//将节点标记为访问过
}
}
}
return d[qx][qy];
} int main()
{
int T;
cin >> T;
for (int t = 0; t < T; t++)
{
input();
int res = bfs();
cout << (res == INF ? -1 : res);
if (t < T - 1)
cout << endl;
}
return 0;
}
CDOJ_149 解救小Q的更多相关文章
- TOJ 2939 解救小Q
描述 小Q被邪恶的大魔王困在了迷宫里,love8909决定去解救她.迷宫里面有一些陷阱,一旦走到陷阱里,就会被困身亡:(,迷宫里还有一些古老的传送阵,一旦走到传送阵上,会强制被传送到传送阵的另一头. ...
- UESTC149 解救小Q
小Q被邪恶的大魔王困在了迷宫里,love8909决定去解救她.迷宫里面有一些陷阱,一旦走到陷阱里,就会被困身亡:(,迷宫里还有一些古老的传送阵,一旦走到传送阵上,会强制被传送到传送阵的另一头.现在请你 ...
- bzoj3007 解救小云公主
3007: 解救小云公主 Time Limit: 5 Sec Memory Limit: 512 MB Submit: 159 Solved: 71 [id=3007" style=&q ...
- 平面直接坐标系线段相交问题(小Q(钟神)的问题)
[问题描述] 小 Q 对计算几何有着浓厚的兴趣.他经常对着平面直角坐标系发呆,思考一些有趣的问题.今天,他想到了一个十分有意思的题目:首先,小 Q 会在?轴正半轴和?轴正半轴分别挑选?个点.随后,他将 ...
- 剑指Offer——网易笔试之解救小易
知识要点 首先介绍一下曼哈顿,曼哈顿是一个极为繁华的街区,高楼林立,街道纵横,从A地点到达B地点没有直线路径,必须绕道,而且至少要经C地点,走AC和 CB才能到达,由于街道很规则,ACB就像一个直角3 ...
- hdu---(4515)小Q系列故事——世界上最遥远的距离(模拟题)
小Q系列故事——世界上最遥远的距离 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)T ...
- HD4505小Q系列故事——电梯里的爱情
Problem Description 细心的同事发现,小Q最近喜欢乘电梯上上下下,究其原因,也许只有小Q自己知道:在电梯里经常可以遇到他心中的女神HR. 电梯其实是个很暧昧的地方,只有在电梯里,小Q ...
- hdu4505小Q系列故事——电梯里的爱情
小Q系列故事——电梯里的爱情 Time Limit: 300/100 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tota ...
- HDU-4515 小Q系列故事——世界上最遥远的距离
小Q系列故事——世界上最遥远的距离 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) ...
随机推荐
- ACM训练联盟周赛 A. Teemo's bad day
65536K Today is a bad day. Teemo is scolded badly by his teacher because he didn't do his homework ...
- Python中的属性访问与描述符
Python中的属性访问与描述符 请给作者点赞--> 原文链接 在Python中,对于一个对象的属性访问,我们一般采用的是点(.)属性运算符进行操作.例如,有一个类实例对象foo,它有一个nam ...
- Zipkin和微服务链路跟踪
https://cloud.tencent.com/developer/article/1082821 Zipkin和微服务链路跟踪 本期分享的内容是有关zipkin和分布式跟踪的内容. 首先,我们还 ...
- 程序员是天生的软件UI设计师
一个软件项目,谁才是软件开发的主体,是软件UI设计师?还是程序员? 这还用问吗?当然是程序员拉.引用以下alienbat知友的一段评论:对于软件开发而言,码农的工作是必需的.设计师的工作是可选的. 举 ...
- Linux 安装 tree命令
通过yum在线安装tree包 yum install tree -y
- 【Mysql 优化 6】mysql优化的内容和思路
根据最近做mysql优化,以及参照的官方文档的一些知识点,总结一下,如何下手去优化mysql 数据库.PS:更多可能是我个人的笔记总结记录,仅供参考 一.优化的内容 可以优化的内容,从范围的大小,可以 ...
- 【转】深入JVM系列(一)之内存模型与内存分配
http://lovnet.iteye.com/blog/1825324 一.JVM内存区域划分 大多数 JVM 将内存区域划分为 Method Area(Non-Heap),Heap,Progr ...
- 【bzoj2346】[Baltic 2011]Lamp 堆优化Dijkstra
题目描述 2255是一个傻X,他连自己家灯不亮了都不知道.某天TZ大神路过他家,发现了这一情况,于是TZ开始行侠仗义了.TZ发现是电路板的问题,他打开了电路板,发现线路根本没有连上!!于是他强大的脑力 ...
- 【bzoj2476】战场的数目 矩阵乘法优化dp
题目描述 (战场定义为对于最高的一列向两边都严格不增的“用积木搭成”的图形) 输入 输入文件最多包含25组测试数据,每个数据仅包含一行,有一个整数p(1<=p<=109),表示战场的图形周 ...
- NOIP2012开车旅行 【倍增】
题目 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为Hi,城市 i 和城 ...