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' 代表警卫(耗 ...
随机推荐
- 【剑指 Offer】05.替换空格
题目描述 请实现一个函数,把字符串 s 中的每个空格替换成"%20". 示例 1: 输入:s = "We are happy." 输出:"We%20a ...
- Java向指定Excel写入读取数据
今天在开发中遇到用户列表导入导出的功能实现,这里了解到使用POI函数库可以完成此任务!特此记录一下 POI Apache POI是Apache软件基金会开放的源码函数库,POI提供API给Java程序 ...
- 【Sed】使用sed删除文件指定行的内容
sed多看帮助文档,受益良多 sed -i '$d' filename 例如删除 /etc/profile的最后一行 cat -n /etc/profile ... 101 export PA ...
- 【Oracle】add_months()函数介绍
add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为单位的) 如:3个月以后的时间,可以用下 ...
- 【ORA】ORA-27090: Unable to reserve kernel resources for asynchronous disk I/O
操作系统是CentOS 5.11 数据库 10.2.0.5.0 晚上查看数据库,发现数据库报错查看相关的trace文件内容如下: *** SERVICE NAME:(SYS$BACKGROUND) 2 ...
- Oracle备份审计表SYS.AUD$和SYS.FGA_LOG$
ORACLE的审计表不可以使用expdp和impdp导出和导入,如果使用,会报如下错误: 需要使用exp和imp进行导出和导出 导出语句: exp " '/ as sysdba' " ...
- ElasticSearch极简入门总结
一,目录 安装es 项目添加maven依赖 es客户端组件注入到spring容器中 es与mysql表结构对比 索引的删除创建 文档的crud es能快速搜索的核心-倒排索引 基于倒排索引的精确搜索. ...
- Flask的配置文件加载两种方式
配置文件 1 基于全局变量 2 基于类的方式 配置文件的加载需要将配合文件的相对路径添加到app.config.from_object("文件路径"),类的方式也是一样,需要将类的 ...
- ROS教程(一):ROS安装教程(详细图文)
ros教程:ros安装 目录 前言 一.版本选择 二.开始安装 2.1 软件中心配置 2.2 添加源 2.3 安装 三.验证ROS 前言 关于ROS(Robot OS 机器人操作系统),估计看这个教程 ...
- 每月一更的《HelloGitHub》第 58 期,来啦!
HelloGitHub 分享 GitHub 上有趣.入门级的开源项目.欢迎大家: 贡献代码 宣传你觉得优秀的项目 Star 项目️ 本月刊是每月 28 号更新,再见月刊就是年后了.在这里提前祝大家:新 ...