题目新颖,解法也是比较难想的。

题目:

Bessie听说有场史无前例的流星雨即将来临;有谶言:陨星将落,徒留灰烬。为保生机,她誓将找寻安全之所(永避星坠之地)。目前她正在平面坐标系的原点放牧,打算在群星断其生路前转移至安全地点。

此次共有M (1 ≤ M ≤ 50,000)颗流星来袭,流星i将在时间点Ti (0 ≤ Ti  ≤ 1,000) 袭击点 (Xi, Yi) (0 ≤ Xi ≤ 300; 0 ≤ Yi ≤ 300)。每颗流星都将摧毁落点及其相邻四点的区域。

Bessie在0时刻时处于原点,且只能行于第一象限,以平行与坐标轴每秒一个单位长度的速度奔走于未被毁坏的相邻(通常为4)点上。在某点被摧毁的刹那及其往后的时刻,她都无法进入该点。

寻找Bessie到达安全地点所需的最短时间。

Input - 输入

* 第1行: 一个整数: M
* 第2..M+1行: 第i+1行包含由空格分隔的三个整数: Xi, Yi, and Ti

Output - 输出

* 仅一行: Bessie寻得安全点所花费的最短时间,无解则为-1。

Sample Input - 输入样例

4
0 0 2
2 1 2
1 1 2
0 3 5

Sample Output - 输出样例

5

代码:

#include<stdio.h>
#include<iostream>
using namespace std;
#include<stdio.h>
#include<string>
#include<queue>
#include<string.h>
int s[4]={0,0,1,-1};
int s1[4]={1,-1,0,0};
const int maxn=310;
int a[maxn][maxn];    //地图
int vis[maxn][maxn];  //标记数组
typedef long long ll;typedef struct node
{int x,y,time;bool operator< (const node&b)const {return time > b.time;}
}point;int min(int a,int b)
{return a>b?b:a;
}void bfs(int x,int y)
{memset(vis,0,sizeof(vis));priority_queue<point>q;point t;t.x=x;t.y=y;t.time=0;q.push(t);vis[x][y]=1;while(!q.empty()){point s2=q.top();q.pop();if(a[s2.x][s2.y]==-1){printf("%d\n",s2.time);return ;}for(int i=0;i<4;i++){point temp;temp.x=s2.x+s[i];temp.y=s2.y+s1[i];temp.time=s2.time+1;if(temp.x>=0&&temp.y>=0&&(a[temp.x][temp.y]==-1||a[temp.x][temp.y]>temp.time)){if(!vis[temp.x][temp.y])q.push(temp);vis[temp.x][temp.y]=1;}}}printf("-1\n");
}
int main()
{int n;while(scanf("%d",&n)!=EOF){int x,y,time;memset(a,-1,sizeof(a));for(int i=0;i<n;i++){scanf("%d%d%d",&x,&y,&time);//cin>>x>>y>>time;if(a[x][y]==-1)a[x][y]=time;elsea[x][y]=min(time,a[x][y]);for(int j=0;j<4;j++){int xx=x+s[j];int yy=y+s1[j];if(xx>=0&&yy>=0){if(a[xx][yy]==-1)a[xx][yy]=time;elsea[xx][yy]=min(a[xx][yy],time);}}}bfs(0,0);}return 0;
}

代码首先是把地图先处理一遍,因为有要求,流行爆炸过的地方不能走,和几秒后流行爆炸的地方是不能走的(在爆炸之前走过去)。对地图进行初始值操作地图全为 -1,流星炸过(将要炸)的地方标记为爆炸的时间,并且前后左右四个方向都会遭殃,也标记为爆炸时间,如果爆炸地点重复,就更新为最短的时间。这道题目的特殊性是先进行标记处理,然后再去BFS搜索最短的时间,因为有一些爆炸过的点作为障碍,就用优先队列(好像普通的队列也可以)对时间进行最小的排序,得到最小时间。

总结:对地图有一些更高的要求,就事先处理地图,处理好后,再进行BFS操作,又是一个新的思路,事先处理好地图的相关操作。

POJ 3669(优先队列BFS)(对地图进行优化)相关推荐

  1. POJ 2312 Battle City 优先队列+BFS

    相信坦克大战大家都玩过吧,本题就是根据这个游戏设计的.坦克要从起点(Y),到目的地(T),坦克不能通过钢墙(S),河(R),可以在空地在行走(E),射击破坏砖墙(B),射击砖墙时不行走且花费一个单位的 ...

  2. POJ 3669-Meteor Shower [bfs] 《挑战程序设计竞赛》2.1

    题目链接: POJ 3669 Meteor Shower 题目大意: 你在坐标原点, 只能在第一象限沿着x,y轴方向移动, 单位时间内一次移动一格.马上将要迎来一场流星雨, 也只会落到第一象限, 每颗 ...

  3. LeetCode 1102. 得分最高的路径(优先队列BFS/极大极小化 二分查找)

    文章目录 1. 题目 2. 解题 2.1 优先队列BFS 2.2 极大极小化 二分查找 1. 题目 给你一个 R 行 C 列的整数矩阵 A.矩阵上的路径从 [0,0] 开始,在 [R-1,C-1] 结 ...

  4. 【SLAM学习笔记】12-ORB_SLAM3关键源码分析⑩ Optimizer(七)地图融合优化

    2021SC@SDUSC 目录 1.前言 2.代码分析 1.前言 这一部分代码量巨大,查阅了很多资料结合来看的代码,将分为以下部分进行分析 单帧优化 局部地图优化 全局优化 尺度与重力优化 sim3优 ...

  5. 百度地图行政区优化卡顿问题

    百度地图行政区优化卡顿 只筛选一个区域 沿海城市会出现多个区域,比如上海有4个区域,一个是主区域,外加三个岛屿,把三个岛屿排除掉 // 获取行政区的时候有可能会出现多个行政区,只获取最大的行政区域le ...

  6. (01)ORB-SLAM2源码无死角解析-(63) BA优化(g2o)→局部建图线程:Optimizer::LocalBundleAdjustment→位姿与地图点优化

    讲解关于slam一系列文章汇总链接:史上最全slam从零开始,针对于本栏目讲解的(01)ORB-SLAM2源码无死角解析链接如下(本文内容来自计算机视觉life ORB-SLAM2 课程课件): (0 ...

  7. supermap地图风格优化

    supermap地图风格优化 地图如果直接拉进数据的话会显得很乱如下图 这个时候就需要我们对他进行一些风格设置,来使地图显得更加美观我们需要给地图设置一些风格设置,比如设置颜色使地图变得更加美观, 但 ...

  8. 二维地图性能优化(一)

    二维地图性能优化(一) 开发工具与关键技术: SuperMap iDesktop 9D.SuperMap GIS撰写时间:2020年5月16日 今天,我要和大家分享的技术是二维地图性能优化. 在我们的 ...

  9. 百度地图排名优化及标注

    百度地图标注,是专门服务于本地商户的一种新型营销模式,你可以在百度地图自主管理您的详情页面,丰富营业信息,让客户全方位了解您并找到你.百度地图标注时可以添加公司名称.地址.电话及400电话.让目标客户 ...

最新文章

  1. 【ICLR 2022】在注意力中重新思考Softmax,多个任务达到SOTA
  2. 再谈Erlang代码热替换
  3. 介绍一个Excel批量处理软件
  4. Sublime Text 3无法安装Package Control插件的解决
  5. spring jdbcTemplate 插入对象返回主键值
  6. myeclipse的电商系统模板_电商市场分析怎么做?3分钟了解程序员必备分析软件...
  7. 控制系统计算机仿真源码,控制系统计算机仿真-实验五.doc
  8. js 加入收藏,设为首页
  9. paddle 图标注_SPC控制图应用步骤
  10. python筛选同义词_Python-比较同义词NLTK
  11. Android 源码编译生成framework.jar
  12. 中国移动号码手机开机以及注册gprs流程
  13. 一个app从设想到上线运营的完整过程
  14. Linux常用命令之Linux常用命令实战知识点
  15. Android-回传数据(装备选择)
  16. python类中最大的_python类的学习笔记(一)
  17. 【C# Lab】0003 《C#入门经典》Ch11 集合、比较和转换 章后习题
  18. 发现一款在线快速传输长视频文件神器,堪比黑科技
  19. 物联网操作系统Zephyr(入门篇)之1.1 Zephyr源码架构
  20. 利用图的广度优先遍历解决城市最短路径问题

热门文章

  1. Vista上StarForce驱动的卸载
  2. C#|Winform编程之(列表视图控件)listView控件
  3. 计算机网络读书笔记(二)
  4. HTTP状态码code类型
  5. document.getElementsByTagName()返回值
  6. 事业单位计算机类专技岗职称,事业单位改革,专技岗和管理岗哪个好?
  7. Android 什么是Hook
  8. 如何学习虚拟现实技术vr? vr初级入门教程开始
  9. linux VFS概述以及内核源代码分析
  10. java list 随机获取n个_java – 从列表中取n个随机元素?