这题的话,卡了有两个小时左右,首先更新地图的时候越界了,我们进行更新的时候,要判断一下是不是小于零了,越界就会Runtime Error。

然后bfs 的时候,我没有允许它搜出300以外的范围,然后就在300以内搜,然后就错了,实际上题目的意思是流星雨的轰炸范围是0~300,然后我就把世界理解成了300,哼,英文很烂,难受。

所以地图开的大一点,然后直接搜就可以了,这题的思路还是好想的。

#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
const int INF = 0x3f3f3f3f;
int map[305][305];
int vis[305][305];
int d[5][2] = {{0, 0}, {1, 0}, {-1, 0}, {0, 1}, {0, -1}};
int m; struct Step {
int x, y, t;
Step(int a,int b,int c):x(a),y(b),t(c){}
}; int bfs()
{
if (!map[0][0])
return INF;
vis[0][0] = 1;
queue<Step> q;
q.push(Step(0, 0, 0));
while (!q.empty()) {
Step now = q.front();
if (map[now.x][now.y]==INF)
return now.t;
for (int i = 1; i < 5;i++) {
int dx = now.x + d[i][0];
int dy = now.y + d[i][1];
if (dx>=0&&dy>=0&&map[dx][dy]>now.t+1&&!vis[dx][dy]) {
vis[dx][dy]=1;
q.push(Step(dx, dy, now.t + 1));
}
}
q.pop();
}
return INF;
} int main()
{
int x, y, t;
while (scanf("%d",&m)!=EOF) {
memset(map, INF, sizeof(map));
memset(vis, 0, sizeof(vis));
while (m--) {
scanf("%d%d%d", &x, &y, &t);
for (int i = 0; i < 5;i++) {
int dx = x + d[i][0];
int dy = y + d[i][1];
if (dx>=0&&dy>=0&&t<map[dx][dy]) {
map[dx][dy]=t;
}
}
}
int min=bfs();
printf("%d\n", min == INF ? -1 : min);
}
return 0;
}

最新文章

  1. 分佈式事務故障處理暨ORA-24756: transaction does not exist處理
  2. 基于OWIN WebAPI 使用OAUTH2授权服务【授权码模式(Authorization Code)】
  3. Ibatis学习总结3--SQL Map XML 映射文件
  4. 进度太慢了,扫频仪PCB
  5. Best Practice: Avoiding or minimizing synchronization in servlets
  6. Android通过http协议POST传输方式
  7. 图片的css自适应
  8. FFmpeg的HEVC解码器源码简单分析:解析器(Parser)部分
  9. MatplotLib常用基本操作
  10. WPF:获取DataGrid控件单元格DataGridCell
  11. 基于MySQL + Node.js + Leaflet的离线地图展示,支持百度、谷歌、高德、腾讯地图
  12. ASP.NET MVC 学习笔记-7.自定义配置信息(后续)
  13. tensorflow 批次读取文件内的数据,并将顺序随机化处理. --[python]
  14. [iOS] 测试设备解决自签名证书问题
  15. Shell脚本1-20例
  16. Python3自动化运维之Fabric模版详解
  17. Java之Jacob调用COM接口DLL-----------------------------------dm。dll
  18. crontab 安装与配置
  19. h5新增加的存储方法
  20. android listview的HeadView左右切换图片(仿新浪,网易,百度等切换图片)

热门文章

  1. XHTML学习笔记 Part2:核心元素
  2. ubuntu 14 安装XML::Simple 模块
  3. Maven - settings.xml里的offline节点的作用
  4. java多线程模拟红绿灯案例
  5. 应用日志获取-web系统
  6. SSAS 维度属性自定义排序
  7. 使用SpringCloud-Netflix
  8. Redis 数据导入导出,redis-dump命令
  9. 用vue.js重构订单计算页面
  10. java 并发容器一之ConcurrentHashMap(基于JDK1.8)