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' 代表警卫(耗 ...
随机推荐
- Java菜鸟在IP问题踩坑了
之前有做过获取客户端公网IP的项目 一般都是 正常的request.getRemoteAddr 或者request.getRemoteHost 可获取到客户端的公网IP, 或者项目部署在有nginx代 ...
- Oracle获取session的IP方法
方法1 创建触发器: create orreplace trigger login_on alfterlogon on database begin dbms_application_info ...
- oracle新增ID主键列,如何补全旧数据的ID值
1.创建SEQUENCE CREATE SEQUENCE MONKEY.TEST_ADD_IDCOL_ID CACHE 100; 2.新增表栏位 ALTER TABLE MONKEY.TEST_ADD ...
- 删除开发账号的ACCESS KEY
大家都知道,当申请一个开发账号来开发程序的时候需要一个ACCESS key,这个key我们可以通过系统管理员在OSS上注册, 也可以通过一些软件来计算,比如zapgui.EXE,但是当用软件注册完,不 ...
- 关于Mysql数据库建库字符集utf8mb4下,排序规则utf8mb4_bin和utf8mb4_general_ci选择造成的查询匹配大小写问题
场景描述: 项目采用了分库模式进行不同业务的开发,在共有的功能模块进行设计的时候采用主从库,或者各分库之中存在同样的库表结构,在使用过程中做库表同步的时候一定要保证库表所在的数据库的字符集和编码格式是 ...
- centos7制作U盘启动盘-九五小庞
一.准备相关软件 1.8G以上U盘 2.UltraISO虚拟光驱(试用版即可)最新版 下载地址:https://cn.ultraiso.net/xiazai.html 点击下载试用 3.CentOS ...
- Ajax编程基础
目录 Ajax编程基础 传统网站中存在的问题 Ajax概述 Ajax的应用场景 Ajax的运行环境 Ajax运行原理及实现 Ajax运行原理 Ajax的实现步骤 1.创建Ajax对象 2.告诉Ajax ...
- 如何将python中pip源设置为国内源
1.Windows Python的学习过程中,往往会学习到很多库,而安装各类库的时候,往往不尽人意,下载速度从几KB到十几KB.甚至下载到一半还超时报错.这都是因为pip源是访问国外的官方源,如果需要 ...
- 编译Nacos,解决No Server available 以及 failed to req API__nacos_v1_ns_instance after all servers
问题描述:如图,显示没有服务可用 仔细看控制台,看到上面Error部分,相关参数没有读取到配置信息,那么配置信息这块似乎是有问题,赶紧看看IDE对配置信息的扫描情况: 可以看到有信息了,但是报错:No ...
- REST 架构的替代方案 为什么说GraphQL是API的未来?
Managing enterprise accounts - GitHub Docs https://docs.github.com/en/graphql/guides/managing-enterp ...