这道题怎么读都不对劲。

管理员的英语应该是语文老师教的。。。都不知道回答的是什么。

题目的大概意思是,在一个n*n的图上,有一些点上有摄影机,初始状态各个摄影机都有一个初始方向,之后每秒顺时针转动90度。

matt有三种移动策略,1是静止在原地(在原地花多1秒),2是不盖箱子走(走到下一个格花1秒),3盖着箱子走(走到下一个花3秒)。要盖箱子的情况:1当前站立的点被摄像机拍到,下一步要走的格子当前时刻被摄像机拍到(而不是下一步要到的点下一时该被摄像机拍到)。

在原地呆的时间不应该超过四秒。

记录下每个格子会在什么时间被拍到。

优化一下内存,记录一下每一个格子到达的最小距离。

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#include <stack>
#include <cmath>
#include <cstdlib>
#include <vector>
#include <map>
#include <iostream>
using namespace std;
char ma[510][510];
struct Info
{int t[4];
}info[510][510];
char dir[5] = "NESW";
const int mov[4][2] = {{-1, 0}, {0, 1}, {1, 0}, {0, -1}};
struct State{ <span style="white-space:pre">   </span>//搜索状态int x, y, dist, stt;State(int _x, int _y, int d, int s): x(_x), y(_y), dist(d), stt(s){}State(){}bool operator < (const State a) const{return dist > a.dist;}
};
int dp[501][501];
void init(const int n, int &sx, int &sy, int &ex, int &ey)
{for(int i = 0; i < n; i++)for(int j = 0; j < n; j++)for(int l = 0; l < 4; l++)info[i][j].t[l] = 1;for(int i = 0; i < n; i++){scanf("%s", ma[i]);for(int j = 0; j < n; j++){int k;for(k = 0; k < 4; k++)if(dir[k] == ma[i][j])break;if(k < 4){for(int l = 0; l < 4; l++)<span style="white-space:pre">       </span>//摄像机周围的点什么时间会被拍到{info[i][j].t[l] = 3;int nx = i + mov[(l + k) % 4][0];int ny = j + mov[(l + k) % 4][1];if(nx < n && ny < n && nx >= 0 && ny >= 0 && ma[nx][ny] != '#'){info[nx][ny].t[l] = 3;<span style="white-space:pre"> </span>}}}else if(ma[i][j] == 'M'){sx = i; sy = j;}else if(ma[i][j] == 'T'){ex = i; ey = j;}}}for(int i = 0; i < n; i++)for(int j = 0; j < n; j++)dp[i][j] = 1000000;
}
priority_queue<State> que;
int main()
{int t;scanf("%d", &t);for(int cas = 1; cas <= t; cas ++){int n;scanf("%d",&n);int sx, sy, ex, ey;init(n, sx, sy, ex, ey);while(!que.empty()) que.pop();que.push(State(sx, sy, 0, 0));ma[sx][sy] = '#';printf("Case #%d: ", cas);while(!que.empty()){State tmp = que.top();if(tmp.x == ex && tmp.y == ey)<span style="white-space:pre">   </span>//搜到终点{printf("%d\n", tmp.dist);break;}que.pop();if(tmp.stt < 4)<span style="white-space:pre">       </span>//停少于4秒que.push(State(tmp.x, tmp.y, tmp.dist + 1, tmp.stt + 1));for(int i = 0; i < 4; i++){int nx = tmp.x + mov[i][0];int ny = tmp.y + mov[i][1];if(nx < n && ny < n && 0 <= nx && 0 <= ny && ma[nx][ny] != '#'){   int dist = tmp.dist + 1;if(info[nx][ny].t[(tmp.dist) % 4] == 3)dist = tmp.dist + 3;if(info[tmp.x][tmp.y].t[tmp.dist % 4] == 3)dist = tmp.dist + 3;if(dist < dp[nx][ny]){dp[nx][ny] = dist;que.push(State(nx, ny, dist, 0));<span style="white-space:pre">      </span>//下一个状态}}}}if(que.empty()){printf("-1\n");}}return 0;
}

网络赛 Instrusive (HDU-5040)相关推荐

  1. 2019CCPC网络赛 1002 HDU 6703(权值线段树)

    2019CCPC网络赛 1002 HDU 6703(权值线段树) 思路:用权值线段树存题目给的数据后,2操作就是求权值线段树中大于等于k的部分中,靠近左端点的第一个大于r的值(这个求出来的只是原序列中 ...

  2. 2014广州网络赛1003||hdu 5024 搜索

    http://acm.hdu.edu.cn/showproblem.php?pid=5024 Wang Xifeng's Little Plot Time Limit: 2000/1000 MS (J ...

  3. Instrusive hdu 5040 优先队列+BFS

    题目描述: The legendary mercenary Solid Matt gets a classic mission: infiltrate a military base. The mil ...

  4. 2014 ACM/ICPC 北京赛区网络赛解题报告汇总

    首页 算法竞赛» 信息聚合 ONLINE JUDGE 书刊杂志 BLOG» 新闻故事» 招聘信息» 投稿须知 2014 ACM/ICPC 北京赛区网络赛解题报告汇总 九月 21st, 2014 | P ...

  5. hdu 5040 Instrusive【BFS+优先队列】

    2014北京网络赛09题,hdu 5040 这次网络赛真是惨,也怪做题策略没想好,当时切完签到题之类的水题之后,马上就去看06青蛙那题去了.结果被那只死青蛙给坑惨了T_T...搞了四小时没搞出来... ...

  6. ACM练级日志:HDU 4735(ACM 成都网络赛) 重复覆盖与DLX

    今天费了一下午+一晚上的劲,终于把重复覆盖问题给解决了.作为这算法的牺牲品的就是成都网络赛让我知道DLX这东西存在的那道题,HDU 4735.这也是第一次尝试独立对问题构造矩阵然后调用DLX得出结果的 ...

  7. 乌鲁木齐网络赛J题(最小费用最大流模板)

    ACM ICPC 乌鲁木齐网络赛 J. Our Journey of Dalian Ends 2017-09-09 17:24 243人阅读 评论(0) 收藏 举报  分类: 网络流(33)  版权声 ...

  8. 2019 ACM - ICPC 上海网络赛 E. Counting Sequences II (指数型生成函数)

    繁凡出品的全新系列:解题报告系列 -- 超高质量算法题单,配套我写的超高质量题解和代码,题目难度不一定按照题号排序,我会在每道题后面加上题目难度指数(1∼51 \sim 51∼5),以模板题难度 11 ...

  9. ACM网络赛金华赛区的一道关于树的题:Family Name List

    三场网络赛终于告一段落了!唉,实力太弱了!跟北大.清华这些家伙差距太远了,比"我在你身边你却不知道我爱你"的距离还要远! 这道题没有来得及提交,自己下来写完的,把样例过了!留在博客 ...

最新文章

  1. linux 关机 司机,Linux 关机
  2. ApiDoc官方文档
  3. 计算机索引无法使用情况,电脑上出现索引,电脑卡的什么都打不开
  4. 关于左右滚动,控制某几列不动
  5. 剑指 Offer II 014. 字符串中的变位词
  6. silverlight中数据绑定讲解
  7. 《Head First设计模式》读书笔记_第一章
  8. 股票开盘的最大成交额-----一道不错的贪心算法题目
  9. mysql关联查询 事务 索引 外键
  10. java innodb存储引擎_MySQL InnoDB存储引擎的事务隔离级别
  11. ubuntu 重装系统备份数据 ubuntu安装kde桌面
  12. JavaScript常见的网页特效(元素样式相关属性)
  13. 【测评】思维导图的战争!手绘和数字思维导图哪个更实用?
  14. 浅谈用户研究那些事(上)定性研究
  15. 调用MapReduce对文件各个单词出现的次数进行统计
  16. 用python爬取qq空间内容_用python爬取QQ空间
  17. 等待事件:Streams AQ: qmn coordinator waiting for slave to start
  18. 一个30岁的人给你提个醒:不管收入多少,你一定要养成存钱习惯
  19. 高德地图报错updatePrivacyShow、updatePrivacyAgree若未正确设置有崩溃风险-解决方案
  20. 数字化工厂的定义及建设目标和意义

热门文章

  1. 天才少年!90后计算机博士刚毕业,年薪达200万!
  2. 虚拟机部署Gitlab + 配置QQ,网易邮箱
  3. 第九章、python中常用函数及方法------打开函数open,写入write、writelines,读取read、readlines、 readline
  4. 【版本升级】Eclipse超强插件CodeMix发布v3.0
  5. 四大力量颠覆软件行业
  6. 【容器】Podman和常用命令
  7. Django 缓存----数据库缓存
  8. ETL流程、数据流图及ETL过程解决方案
  9. 使用Android Studio 3.2编译android-serialport-api JNI
  10. 关于Rhino中没有Moldex3d Mesh外挂的解决办法