HDOJ 1242
纠结1242很久了,查了题解才发现要优先队列才能成功
http://blog.chinaunix.net/uid-21712186-id-1818266.html 使人开窍之文章
优先队列,已经不算是FIFO的队列了,而是一种以优先级(可以是值的大小等等)进行动态插入数值的一种“伪队列”,其中优先队列是用堆
而优先队列中与BFS的关系便在于,BFS的出队便是代表着
使用方法与队的方法差不多,(STL)
接下来是代码与解析
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int SIZE=300;
int M,N;
char map[SIZE][SIZE];
int x1,y1;
int dir[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
typedef struct point
{
int x,y;
int t;
bool operator < (const point &a)const // 对"<"符号的重定义
{
return t>a.t;
}
}point;
int over(point a)
{
if(a.x<0||a.y<0||a.x==N||a.y==M) return 1;
return 0;
}//越界处理
int bfs()
{
priority_queue<point> q;
point sp,p,tmp;
sp.x=x1;sp.y=y1;sp.t=0;
map[sp.y][sp.x]='#';
q.push(sp);
while(!q.empty())
{
tmp=q.top();
q.pop();
for(int i=0;i<4;i++)
{
p.x=tmp.x+dir[i][0];
p.y=tmp.y+dir[i][1];
p.t=tmp.t+1;
if(over(p)) continue;
if(map[p.y][p.x]=='#') continue;
if(map[p.y][p.x]=='r') return p.t;
if(map[p.y][p.x]=='.')
{
map[p.y][p.x]='#';
q.push(p);
}
else
{
map[p.y][p.x]='#';
p.t++;//精髓所在
q.push(p);
}
}
}
return -1;
}
int main()
{
//freopen("data.in","r",stdin);
int i,j,ret;
while(scanf("%d%d",&M,&N)!=EOF)
{
for(i=0;i<M;i++)
scanf("%s",map[i]);
for(i=0;i<M;i++)
for(j=0;j<N;j++)
if(map[i][j]=='a')
{
x1=j;
y1=i;
}
ret=bfs();
if(ret==-1) printf("Poor ANGEL has to stay in the prison all his life.\n");
else printf("%d\n",ret);
}
return 0;
}
http://blog.csdn.net/listeningsea/article/details/7718484
HDOJ 1242的更多相关文章
- HDOJ并查集题目 HDOJ 1213 HDOJ 1242
Problem Description Today is Ignatius' birthday. He invites a lot of friends. Now it's dinner time. ...
- hdoj 1242 Rescue
Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- BFS HDOJ 1242 Rescue
题目传送门 题意:从r走到a,遇到x多走一步,问最小走到a的步数 分析:因为r有多个,反过来想从a走到某个r的最小步数,简单的BFS.我对这题有特殊的感情,去年刚来集训队时肉鸽推荐了这题,当时什么都不 ...
- BFS && DFS
HDOJ 1312 Red and Black http://acm.hdu.edu.cn/showproblem.php?pid=1312 很裸的dfs,在dfs里面写上ans++,能到几个点就调了 ...
- HDOJ(1242)BFS+优先队列
Rescue http://acm.hdu.edu.cn/showproblem.php?pid=1242 题意:"#"是墙,"."是路,"a&quo ...
- 【HDOJ】1242 Rescue
BFS+优先级队列. #include <iostream> #include <cstdio> #include <cstring> #include <q ...
- HDOJ/HDU 1242 Rescue(经典BFS深搜-优先队列)
Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The prison is ...
- 杭电hdoj题目分类
HDOJ 题目分类 //分类不是绝对的 //"*" 表示好题,需要多次回味 //"?"表示结论是正确的,但还停留在模块阶 段,需要理解,证明. //简单题看到就 ...
- hdu 1242 Rescue
题目链接:hdu 1242 这题也是迷宫类搜索,题意说的是 'a' 表示被拯救的人,'r' 表示搜救者(注意可能有多个),'.' 表示道路(耗费一单位时间通过),'#' 表示墙壁,'x' 代表警卫(耗 ...
随机推荐
- Linux下安装Oracle11g服务器【转】
安装环境 Linux服务器:oracle linux 6.6 64位 Oracle服务器:Oracle11gR2 64位 系统要求 Linux安装Oracle系统要求 系统要求 说明 内存 必须高于1 ...
- Nginx+FFmpeg实现RTSP转RTMP
RTSP转RTMP 本次转流采用Centos+Nginx+FFmpeg实现,具体实现如下: 1. 安装Ngxin 安装详细略(可以选择安装阿里的Tengine,官方[下载路径](Download - ...
- 修改hosts文件后不生效,该怎么办
对于web开发来说,经常需要修改hosts文件,用来将域名与ip对应匹配.但是有时候发现hosts文件明明已经改了,但就是不生效,页面还会跳到某个丧心病狂的私人小站.hosts文件不生效有很多种原因, ...
- innnodb_doublewrite
有写场景下,双写缓冲确实没必要,例如,你也许像在备库上禁用双写缓冲,此外,一些文件系统,例如zfs做了同样的事,所以,没必要再让innodb做一遍. innodb_double_write=0 即可关 ...
- HATEOAS的简单认识
HATEOAS: 超媒体作为应用程序状态引擎(HATEOAS)是REST应用程序体系结构的一个组件,它将其与其他网络应用程序体系结构区分开来. 使用HATEOAS,客户端与网络应用程序交互,其应用程序 ...
- 【pytest】(十)fixture参数化-巧用params和ids优雅的创建测试数据
我们都知道参数化. 比如我要测试一个查询接口/test/get_goods_list,这个接口可以查询到商品的信息. 在请求中,我可以根据请参数goods_status的不同传值,可以查询到对应状态的 ...
- 一站式入口服务|爱奇艺微服务平台 API 网关实战 原创 弹性计算团队 爱奇艺技术产品团队
一站式入口服务|爱奇艺微服务平台 API 网关实战 原创 弹性计算团队 爱奇艺技术产品团队
- threading.RLock()
# Copyright 2001-2017 by Vinay Sajip. All Rights Reserved.## Permission to use, copy, modify, and di ...
- websocket心跳重连 websocket-heartbeat-js
初探和实现websocket心跳重连(npm: websocket-heartbeat-js) 心跳重连缘由 websocket是前后端交互的长连接,前后端也都可能因为一些情况导致连接失效并且相互之间 ...
- Python中,单引号,双引号,三引号的使用区别与原因
先说1双引号与3个双引号的区别,双引号所表示的字符串通常要写成一行如:s1 = "hello,world"如果要写成多行,那么就要使用/ ("连行符")吧,如s ...