解题心得:

1.读清楚题意,本题的题意是有多个‘r’(起点),多个r多个bfs比较最短的时间即可,但是hdoj的数据比较水,直接一个起点就行了,迷宫里有多个守卫,如果在路途中遇到守卫会多花费一个时间点,求最短时间救到公主。

2.(解法一)因为遇到守卫会多花费一个时间,所以在守卫的地方再次压入,但是时间加一,这样就可以让队列里面的先验证。

3.之前将此题理解为要将所有的守卫打败之后,才能救到天使,之前题意理解错误用了回溯法,找出所有打败全部守卫的情况,找到最短的路径。此题的数据0<n<m<=200,很明显的会超时。

4.(解法二)使用优先队列,虽然看起来和解法一相差不大,但是如果打败守卫的时间不同那么解法二将明显更方便。

题目:

Rescue

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Total Submission(s): 29754    Accepted Submission(s): 10489

Problem Description

Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The prison is described as a N * M (N, M <= 200) matrix. There are WALLs, ROADs, and GUARDs in the prison.

Angel's friends want to save Angel. Their task is: approach Angel. We assume that "approach Angel" is to get to the position where Angel stays. When there's a guard in the grid, we must kill him (or her?) to move into the grid. We assume that we moving up,
down, right, left takes us 1 unit time, and killing a guard takes 1 unit time, too. And we are strong enough to kill all the guards.

You have to calculate the minimal time to approach Angel. (We can move only UP, DOWN, LEFT and RIGHT, to the neighbor grid within bound, of course.)

 

Input

First line contains two integers stand for N and M.

Then N lines follows, every line has M characters. "." stands for road, "a" stands for Angel, and "r" stands for each of Angel's friend.

Process to the end of the file.

 

Output

For each test case, your program should output a single integer, standing for the minimal time needed. If such a number does no exist, you should output a line containing "Poor ANGEL has to stay in the prison all his life."

 

Sample Input

7 8

#.#####.

#.a#..r.

#..#x...

..#..#.#

#...##..

.#......

........

 

Sample Output

13

 

Author

CHEN, Xue



解法一代码:
#include<stdio.h>
#include<queue>
#include<cstring>
using namespace std;
struct node
{
int x,y,step;
}now,Next;
char maps[210][210];
int use[210][210],n,m;
int dir[4][2]={1,0,-1,0,0,1,0,-1}; bool check(int x,int y)
{
if(x<0 || y<0 || x>=n || y>=m || use[x][y] || maps[x][y] == '#')
return false;
else
return true;
}
void maps_store()
{ for(int i=0;i<n;i++)
{
scanf("%s",maps[i]);
for(int j=0;j<m;j++)
{
if(maps[i][j] == 'r')
{
now.x = i;
now.y = j;
now.step = 0;
}
}
}
} void bfs()
{
queue <node> qu;
qu.push(now);
use[now.x][now.y] = 1;
while(!qu.empty())
{
now = qu.front();
qu.pop();
if(maps[now.x][now.y] == 'a')
{
printf("%d\n",now.step);
return ;
}
if(maps[now.x][now.y] == 'x')
{
maps[now.x][now.y] = '.';
now.step = now.step + 1;
use[now.x][now.y] = 1;
qu.push(now);//再次压入
continue;
}
for(int i=0;i<4;i++)
{
Next.x = now.x + dir[i][0];
Next.y = now.y + dir[i][1];
Next.step = now.step + 1;
if(check(Next.x,Next.y))
{
use[Next.x][Next.y] = 1;
qu.push(Next);
}
}
}
printf("Poor ANGEL has to stay in the prison all his life.\n");
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(use,0,sizeof(use));
maps_store();
bfs();
}
}


解法二代码:


#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
using namespace std;
const int maxsize = 210;
int n,m,dir[4][2] = {1,0,-1,0,0,1,0,-1},use[maxsize][maxsize];
char map[maxsize][maxsize];
struct node
{
int x,y,time;
friend bool operator < (node a,node b)//队列中排序的判断,注意写法
{
return a.time>b.time;
}
} now,Next; priority_queue <node> pr_qu;//优先队列 void map_store()
{
for(int i=0; i<n; i++)
cin>>map[i];
for(int i=0; i<n; i++)
{
for(int j=0; j<m; j++)
{
if(map[i][j] == 'r')
{
now.x = i;
now.y = j;
now.time = 0;
use[now.x][now.y] = 1;
return;
}
}
}
} bool check(int x,int y)
{
if(x<0 || y<0 || x>=n || y>=m || map[x][y] == '#' || use[x][y] == 1)
return false;
else
return true;
} int bfs()
{
while(!pr_qu.empty())
pr_qu.pop();
pr_qu.push(now);
while(!pr_qu.empty())
{
now = pr_qu.top();
if(map[now.x][now.y] == 'a')
return now.time;
for(int i=0; i<4; i++)
{
Next.x = now.x + dir[i][0];
Next.y = now.y + dir[i][1];
if(check(Next.x,Next.y))
{
if(map[Next.x][Next.y] == 'x')//注意这部分的位置
Next.time = now.time + 2;
else
Next.time = now.time + 1;
pr_qu.push(Next);
use[Next.x][Next.y] = 1;
}
}
pr_qu.pop();
}
return -1;//没有找到a时返回-1
}
int main()
{
while(cin>>n>>m)
{
memset(use,0,sizeof(use));
map_store();
int Time = bfs();
if(Time == -1)
cout<<"Poor ANGEL has to stay in the prison all his life."<<endl;
else
cout<<Time<<endl;
}
}

BFS:HDU-1242-Rescue(带守卫的迷宫问题)(优先队列)的更多相关文章

  1. hdu 1242 Rescue (BFS)

    Rescue Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  2. hdu 1242 Rescue

    题目链接:hdu 1242 这题也是迷宫类搜索,题意说的是 'a' 表示被拯救的人,'r' 表示搜救者(注意可能有多个),'.' 表示道路(耗费一单位时间通过),'#' 表示墙壁,'x' 代表警卫(耗 ...

  3. ZOJ-1649 Rescue BFS (HDU 1242)

    看题传送门: ZOJ http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1649 HDU http://acm.hdu.edu. ...

  4. hdu 1242:Rescue(BFS广搜 + 优先队列)

    Rescue Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submis ...

  5. hdu - 1242 Rescue && hdu - 2425 Hiking Trip (优先队列+bfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=1242 感觉题目没有表述清楚,angel的朋友应该不一定只有一个,那么正解就是a去搜索r,再用普通的bfs就能过了 ...

  6. hdu 1242 Rescue(bfs)

    此刻再看优先队列,不像刚接触时的那般迷茫!这也许就是集训的成果吧! 加油!!!优先队列必须要搞定的! 这道题意很简单!自己定义优先级别! +++++++++++++++++++++++++++++++ ...

  7. HDU 1242 Rescue(BFS+优先队列)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1242 题目描述: Problem Description Angel was caught by t ...

  8. HDU 1242 -Rescue (双向BFS)&amp;&amp;( BFS+优先队列)

    题目链接:Rescue 进度落下的太多了,哎╮(╯▽╰)╭,渣渣我总是埋怨进度比别人慢...为什么不试着改变一下捏.... 開始以为是水题,想敲一下练手的,后来发现并非一个简单的搜索题,BFS做肯定出 ...

  9. HDU 1242 Rescue (BFS(广度优先搜索))

    Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

随机推荐

  1. babel7中 preset-env 完全使用

    babel7中 preset-env 完全使用 const presets = [ ['@babel/env', { // chrome, opera, edge, firefox, safari, ...

  2. Windows系统HTTP身份验证方法

    当Windows客户端尝试使用HTTP协议访问基于Web的资源时,会在客户端和服务器之间建立"对话".换句话说,服务器告诉客户端,访问资源之前进行身份验证 ,并且服务器还告诉客户端 ...

  3. 使用tooltip显示jquery.validate.unobtrusive验证信息

    通过重写CSS实现使用tooltip显示jquery.validate.unobtrusive验证信息,效果如图: 1. 在ViewModel中定义验证规则 [Display(Name = " ...

  4. 上传高德地图-express框架

    1.首先要注册高德地图,完后成为开发者 2.控制台里获取自己的key值 3.在要显示地图的页面添加如下的代码 <script type="text/javascript" s ...

  5. LeetCode Valid Palindrome 有效回文(字符串)

    class Solution { public: bool isPalindrome(string s) { if(s=="") return true; ) return tru ...

  6. html body上有一条空白!!!

    html body 上莫名其妙的就出现了一条空白,怎么搞都搞不定,弄了一下午...... 解决了!!! 格式问题/

  7. StackOverflow之旅<2>------{HashMap和Hashtable的区别}

    问题 在Java中HashMap和Hashtable的区别? 哪一个对于多线程应用程序更好? 回答 Hashtable是同步的,加了synchronized锁,而HashMap不是.没有加synchr ...

  8. MYSQL短索引

    优化MYSQL时,可以尽量使用短索引,如果只是为了提高读取的速度,可以优先使用聚合索引,把几个字段聚集在一起,当然缺点在于操作(写)的时候会降低效率,短索引一般都是开头几个字符基本不同的时候,可以考虑 ...

  9. oc语言特性

    It’s a superset of the C programming language and provides object-oriented capabilities and a dynami ...

  10. python request下载文件时,显示进度以及网速

    import requests import time def downloadFile(name, url): headers = {'Proxy-Connection':'keep-alive'} ...