http://acm.hdu.edu.cn/showproblem.php?pid=5025

Saving Tang Monk

Problem Description
《Journey to the West》(also 《Monkey》) is one of the Four Great Classical Novels of Chinese literature. It was written by Wu Cheng'en during the Ming Dynasty. In this novel, Monkey King Sun Wukong, pig Zhu Bajie and Sha Wujing, escorted Tang Monk to India to get sacred Buddhism texts.

During the journey, Tang Monk was often captured by demons. Most of demons wanted to eat Tang Monk to achieve immortality, but some female demons just wanted to marry him because he was handsome. So, fighting demons and saving Monk Tang is the major job for Sun Wukong to do.

Once, Tang Monk was captured by the demon White Bones. White Bones lived in a palace and she cuffed Tang Monk in a room. Sun Wukong managed to get into the palace. But to rescue Tang Monk, Sun Wukong might need to get some keys and kill some snakes in his way.

The palace can be described as a matrix of characters. Each character stands for a room. In the matrix, 'K' represents the original position of Sun Wukong, 'T' represents the location of Tang Monk and 'S' stands for a room with a snake in it. Please note that there are only one 'K' and one 'T', and at most five snakes in the palace. And, '.' means a clear room as well '#' means a deadly room which Sun Wukong couldn't get in.

There may be some keys of different kinds scattered in the rooms, but there is at most one key in one room. There are at most 9 kinds of keys. A room with a key in it is represented by a digit(from '1' to '9'). For example, '1' means a room with a first kind key, '2' means a room with a second kind key, '3' means a room with a third kind key... etc. To save Tang Monk, Sun Wukong must get ALL kinds of keys(in other words, at least one key for each kind).

For each step, Sun Wukong could move to the adjacent rooms(except deadly rooms) in 4 directions(north, west, south and east), and each step took him one minute. If he entered a room in which a living snake stayed, he must kill the snake. Killing a snake also took one minute. If Sun Wukong entered a room where there is a key of kind N, Sun would get that key if and only if he had already got keys of kind 1,kind 2 ... and kind N-1. In other words, Sun Wukong must get a key of kind N before he could get a key of kind N+1 (N>=1). If Sun Wukong got all keys he needed and entered the room in which Tang Monk was cuffed, the rescue mission is completed. If Sun Wukong didn't get enough keys, he still could pass through Tang Monk's room. Since Sun Wukong was a impatient monkey, he wanted to save Tang Monk as quickly as possible. Please figure out the minimum time Sun Wukong needed to rescue Tang Monk.

 
Input
There are several test cases.

For each case, the first line includes two integers N and M(0 < N <= 100, 0<=M<=9), meaning that the palace is a N×N matrix and Sun Wukong needed M kinds of keys(kind 1, kind 2, ... kind M).

Then the N × N matrix follows.

The input ends with N = 0 and M = 0.

 
Output
For each test case, print the minimum time (in minutes) Sun Wukong needed to save Tang Monk. If it's impossible for Sun Wukong to complete the mission, print "impossible"(no quotes).
 
Sample Input
3 1
K.S
##1
1#T
3 1
K#T
.S#
1#.
3 2
K#T
.S.
21.
0 0

 
Sample Output
5
impossible
8
题意:要从K走到T处,并且要先收集k把钥匙,收集钥匙顺序递增,即拿到第一把钥匙才能拿到第二把钥匙,还有不超过五条蛇(之前没看到这里只有五条不会做),每次打蛇要+1s,蛇死了再路过是不用打的。
思路:只有五条蛇,给蛇编号然后状压记录打的蛇的状态。剩下的就BFS。一开始用的优先队列,不过超时了。要注意vis数组记录状态的技巧!!!
 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 #include <iostream>
 5 #include <queue>
 6 using namespace std;
 7 #define N 105
 8 #define INF 0x3f3f3f3f
 9
10 struct node
11 {
12     int x, y, t, key, snake;
13     node() {}
14     node(int x, int y, int t, int key, int snake) : x(x), y(y), t(t), key(key), snake(snake) {}
15 };
16 bool vis[N][N][10][40];
17 int n, m, sx, sy, ex, ey;
18 int dx[] = {1, -1, 0, 0}, dy[] = {0, 0, 1, -1};
19 char maze[N][N];
20
21 bool check(int x, int y)
22 {
23     if(0<=x&&x<n&&0<=y&&y<n&&maze[x][y]!='#') return true;
24     return false;
25 }
26
27 void bfs()
28 {
29     int ans = INF;
30     memset(vis, 0, sizeof(vis));
31     queue<node> que;
32     while(!que.empty()) que.pop();
33     que.push(node(sx, sy, 0, 0, 0));
34     while(!que.empty()) {
35         node top = que.front(); que.pop();
36         int x = top.x, y = top.y, key = top.key, snake = top.snake, t = top.t;
37         if(key == m && maze[x][y] == 'T') {
38             ans = min(ans, t);
39         }
40         if(vis[x][y][key][snake] != 0) continue;
41         vis[x][y][key][snake] = 1;
42         for(int i = 0; i < 4; i++) {
43             int nx = x + dx[i], ny = y + dy[i];
44             if(!check(nx, ny)) continue;
45             node now = top;
46             if('A' <= maze[nx][ny] && maze[nx][ny] <= 'G') {
47                 //只有五条蛇,不能写 <= 'Z'
48                 int s = maze[nx][ny] - 'A';
49                 if((1<<s) & now.snake) ; //如果蛇被打了
50                 else {
51                     now.snake |= (1<<s); //没被打
52                     now.t++;
53                 }
54             } else if(maze[nx][ny] - '0' == now.key + 1) {
55                 now.key++;
56             }
57             now.t++;
58             que.push(node(nx, ny, now.t, now.key, now.snake));
59         }
60     }
61     if(ans != INF) printf("%d\n", ans);
62     else printf("impossible\n");
63 }
64
65 int main()
66 {
67     while(~scanf("%d%d", &n, &m), n+m) {
68         int cnt = 0;
69         for(int i = 0; i < n; i++) {
70             scanf("%s", maze[i]);
71         }
72         for(int i = 0; i < n; i++) {
73             for(int j = 0; j < n; j++) {
74                 if(maze[i][j] == 'K') sx = i, sy = j;
75                 if(maze[i][j] == 'S') {maze[i][j] = cnt+'A'; cnt++;}
76             }
77         }
78         bfs();
79     }
80     return 0;
81 }
82
83 /*
84 4 2
85 KS1.
86 2SS.
87 SSSS
88 STSS
89 0 0
90 */

转载于:https://www.cnblogs.com/fightfordream/p/5764470.html

HDU 5025:Saving Tang Monk(BFS + 状压)相关推荐

  1. HDU 5025 Saving Tang Monk(广州网络赛D题)

    HDU 5025 Saving Tang Monk 题目链接 思路:记忆化广搜,vis[x][y][k][s]表示在x, y结点,有k把钥匙了,蛇剩余状态为s的步数,先把图预处理出来,然后进行广搜即可 ...

  2. 2014 网选 广州赛区 hdu 5025 Saving Tang Monk(bfs+四维数组记录状态)

    1 /* 2 这是我做过的一道新类型的搜索题!从来没想过用四维数组记录状态! 3 以前做过的都是用二维的!自己的四维还是太狭隘了..... 4 5 题意:悟空救师傅 ! 在救师父之前要先把所有的钥匙找 ...

  3. bfs+状压——朋也与光玉

    朋也与光玉 本来说好了再做一下之前没写起的题的,但是看到队友写了这道题手还是比较痒,于是就写了. ------------------------------------------ 题解: 这道题和 ...

  4. Saving Tang Monk II HihoCoder - 1828(2018北京网络赛三维标记+bfs)

    <Journey to the West>(also <Monkey>) is one of the Four Great Classical Novels of Chines ...

  5. ACM/ICPC 2018亚洲区预选赛北京赛站网络赛 A Saving Tang Monk II【分层bfs】

    时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 <Journey to the West>(also <Monkey>) is one of the ...

  6. #hihoCoder #1828 : Saving Tang Monk II (分层BFS)

    描述 <Journey to the West>(also <Monkey>) is one of the Four Great Classical Novels of Chi ...

  7. Tunnels HDU - 4856 (bfs状压dp)

    Tunnels HDU - 4856 Bob is travelling in Xi'an. He finds many secret tunnels beneath the city. In his ...

  8. HDU-4856 Tunnels(BFS状压DP)

    Tunnels http://acm.hdu.edu.cn/showproblem.php?pid=4856 Time Limit: 3000/1500 MS (Java/Others)    Mem ...

  9. QDUOJ 来自xjy的签到题(bfs+状压dp)

    来自xjy的签到题 Description 爱丽丝冒险来到了红皇后一个n*n大小的花园,每个格子由'.'或'#'表示,'.'表示爱丽丝可以到达这个格子,'#'表示爱丽丝不能到达这个格子,爱丽丝每1分钟 ...

最新文章

  1. Python爬虫获取文章的标题及你的博客的阅读量,评论量。所有数据写入本地记事本。最后输出你的总阅读量!
  2. python cs开发框架_我的第一个python web开发框架(24)——系统重构与ORM
  3. 关于异步提交form表单
  4. linux链接curl库,Linux利用curl库快速开发http应用
  5. POC of settype read harmonization - using description settype as example
  6. python爬虫 asyncio aiohttp aiofiles 单线程多任务异步协程爬取图片
  7. Qt文档阅读笔记-Text QML Type官方解析及实例
  8. mysql的socket文件_修改socket文件, MySQL启动报错
  9. oracle的分析函数over 及开窗函数[转]
  10. 【Oracle】Drop表后闪回
  11. 公众号文章发送pdf文件 pdf文件如何变成导出图片
  12. Webpack+Babel+React环境搭建
  13. Unity3d资源管理模块
  14. 剪枝算法实现一字棋-C++
  15. 毕业半年,帅地人生的第一个一百万
  16. tplink路由器dns服务器未响应,联通光纤猫连接无线路由器设置教程图解
  17. 《孽海记·思凡》唱段·风吹荷叶煞
  18. android 实现qq动画,Android实现仿QQ登录界面背景动画效果
  19. Debug: defusedxml, CV_LOAD_IMAGE_UNCHANGED,CV_IMWRITE_JPEG_QUALITY,undistortPoints
  20. 微信小程序开发之实现一个弹幕评论

热门文章

  1. 太阳能计算机屏幕是什么材质,魅蓝E的屏幕怎么样?屏幕材质是什么?
  2. android apk自动安装包下载,Android实现应用下载并自动安装apk包
  3. 指纹图谱相似度评价软件_基于指纹图谱和网络药理学对当归四逆汤中桂枝的Qmarker预测分析...
  4. 带有下标的赋值维度不匹配_KDD 2019|?结构感知的神经网络对人才-组织匹配的影响...
  5. 实现暂停一秒输出的效果_从暂停游戏联想到的
  6. flink sql udf jar包_Java动态加载Jar实例解析
  7. 澳大利亚 计算机 博士,澳大利亚迪肯大学招收计算机博士
  8. python爬虫京东中文乱码_python3爬虫中文乱码之请求头‘Accept-Encoding’:br 的问题...
  9. 如何用python画一个心形图_求问怎样用python/python turtle画“心”
  10. unity应用开发实战案例_Unity游戏案例开发大全 (吴亚峰等著) 完整pdf高清版[31MB]...