龙神觉得无聊于是来到了地下城,这里是一个巨大的迷宫,有一些可以通行的路、一些不可以通行的墙,还有一些怪物。虽然龙神可以轻易地干掉这些怪物,但他觉得这样就太没意思了,他观察到这些怪物每 k 秒会消失一次,每一秒龙神可以选择向上下左右行走一步(不能在原地不动)。龙神想知道在避开全部怪物的条件下,到达出口所需要的最短时间。

解题思路:

由于求最短时间,那么这个题就相当于一个从起点到终点的bfs,当搜索到终点的时候一定是时间最短的。

考虑每一次入队我们都要将这个点的状态标记为走过,而地图中有的点与时间有关,这样的话我们就在状态里记在t%k的时间走过这个点即可

代码:

#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>  using namespace std;  typedef pair<int, int> PII;
const int N = 110;
int n,m,k;
int  d[N][N],st[N][N][50];
string g[N];
int sx,sy,ex,ey;
int bfs()
{  queue<PII> q;  d[sx][sy] = 0;  st[sx][sy][0]=1;  q.push({sx, sy});  int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};  while (q.size())  {  auto t = q.front();  q.pop();  int tt=d[t.first][t.second] + 1;  for (int i = 0; i < 4; i ++ )  {  int x = t.first + dx[i], y = t.second + dy[i];  if (x < 0 || x >= n || y < 0 || y >= m ||st[x][y][tt%k])continue;  if( g[x][y] == '#' ){  continue;  }  if(g[x][y]=='*'&&((tt)%k!=0))continue;  st[x][y][tt%k]=1;  d[x][y] = tt ;  q.push({x, y});  if(x==ex&&y==ey)return tt;  }  }  return -1;
}  int main()
{  ios::sync_with_stdio(false);  cin.tie(0);  cout.tie(0);  int t;  cin>>t;  while(t--){  memset(d, 0x3f, sizeof d);  memset(st, 0, sizeof st);  cin >> n >> m>>k;  for (int i = 0; i < n; i ++ ){  cin >> g[i];  for (int j = 0; j < m; j ++ )  {  if(g[i][j]=='S')sx=i,sy=j;  if(g[i][j]=='E')ex=i,ey=j;  }  }  cout << bfs() << endl;  }  return 0;
}  

22. 地下城与勇士相关推荐

  1. 连接黑屏_解决地下城与勇士PK服登录游戏卡在“正在连接服务器”的黑屏界面...

    网吧安装好了地下城与勇士DNF比赛PK服,但总是进不去游戏,具体如下图: 一直卡在"正在连接服务器..."黑屏状态 首先显示隐藏文件和系统文件: 我们先找到存DNF.cfg这个文件 ...

  2. 使用模拟器玩地下城与勇士M电脑版试玩分享

    <地下城与勇士 M>是采用2D横版格斗人气网游IP原作做的一款手游.游戏目前地下城与勇士 Neople 和 腾讯合作研发中,游戏中玩家看到无限连击的动作特性.极富多样化的职业分支.精准的操 ...

  3. DNF登陆的时候说连接服务器失败,请检查您的网络。是否启用修复程序进行修复?,地下城和勇士常见问题修复方法.doc...

    地下城和勇士常见问题修复方法 日常问答 [未使用第三方软件被系统提示使用第三方软件] 解决方案:请到 HYPERLINK "/dnf/index_dnf.htm?t=dnf" \t ...

  4. 浅析《地下城与勇士:决斗》的卡通渲染

    <地下城与勇士:决斗>罪恶装备和碧蓝幻想都是一家叫Arc System Works公司出品的,它们的渲染也是用的同一套思路.我们使用碧蓝幻想的游戏内的资源做一个解析. 模型使用了四张贴图: ...

  5. 怎么把字母缩小当符号_《DNF手游》名字特殊符号怎么打 地下城与勇士M特殊符号取名教学...

    dnf手游名字特殊符号怎么打?在地下城与勇士M中,游戏中很多玩家想取个性化的昵称,加入合适的特殊符号是不错的选择,那么特殊符号怎么打,下面就来告诉大家,一起来看看吧. 地下城与勇士M特殊符号复制介绍 ...

  6. 地下城与勇士M如何用电脑玩 地下城与勇士M电脑版教程

    <地下城与勇士M>是一款根据端游同款游戏改编而来的冒险挑战类手机游戏.在这个暗黑的世界之中,你需要化身为一个超级无比的勇士,你不仅仅需要拥有超级震撼的完美炫斗技能大招,简单畅爽的操作,带你 ...

  7. Java实现——地下城与勇士DNF武器强化(+0——+16)

    Java实现--地下城与勇士DNF武器强化(+0--+16) DNF中强化装备能够为装备增加攻击力,从而增加角色的攻击力.强化的等级越高,增加的攻击越高,但强化装备有着一定的失败 1.运行样例 强化规 ...

  8. 地下城与勇士体验服不显示服务器,地下城与勇士M手游体验服进不去怎么办?内测问题与解决方案汇总[多图]...

    腾讯官方<地下城与勇士M>手游的内测体验服已于2019年12月9日~10日正式开放下载.玩家们已经翘首以盼苦等一年,无论是否还在PC端阿拉德世界征战,听到手游小溪后都会第一时间申请资格并下 ...

  9. 地下城与勇士m服务器维护,地下城与勇士M怎么登不了 登陆不了解决办法

    地下城与勇士M正式版v0.7.2.3 安卓版 类型:动作射击大小:129.5M语言:中文 评分:10.0 标签: 立即下载 地下城与勇士M正在测试中,玩家使用QQ或微信即可登陆游戏,不过有玩家进入游戏 ...

最新文章

  1. 学写jQuery插件开发方法
  2. 从新手到Flutter架构师,一篇就够!吐血整理
  3. Java项目案例大全
  4. [教程]添加yueue.ADOKeycap数据库组件到您的项目
  5. 一些值得注意的算法题——队列、栈
  6. 电子计算机第一代到第四代,从第一代电子计算机到第四代计算机的体系结构都是由运算器、控制器、存储器、输入设备和输出设备组成的,称为( )体系结构。...
  7. 推荐8个不错的视频自动加字幕工具
  8. 8T磁盘阵列文件存储服务器 威联通,NAS私有云老司机折腾体验记 篇八:QNAP 威联通TR-004磁盘阵列外接盒使用教程...
  9. 华为云CentOS7.6云耀服务器Python环境基本配置
  10. 算法创作|模拟商品加入购物车并结算价钱问题解决方法
  11. OPENCV scalar
  12. 天文学论文绘图注意事项
  13. java中 SSL认证和keystore使用
  14. 解决input 中 type=“number“右侧上下箭头以及取消默认滚轮事件
  15. navicat for mysql 模型_Navicat for MySQL 功能简介
  16. 坚果pro2s android 8,坚果Pro2s和小米8se哪个好?坚果Pro2s对比小米8se区别评测
  17. 知云文献翻译打不开_学用系列自带翻译功能的PDF文献阅读器——知云文献翻译3.0...
  18. Integer缓存IntegerCache详解
  19. 从菜鸟到高手,CMD命令行了解arp欺骗攻击的原理
  20. 以前管Facebook叫“脸书” 现在管Meta叫什么呢

热门文章

  1. QQ群 会话颜色参照表
  2. Centos 7(linux)echo 用法的注意事项
  3. 阿里云创建AccessKey
  4. Unity实用小工具或脚本—3D炫酷UI篇(一)
  5. 【BJOI2019】勘破神机【数论】
  6. android 8 奕骆,这才是超级手机 奕骆6000mAh称霸全球 USB Type-C
  7. 日均5亿查询量,京东到家订单中心的ES架构演进
  8. 浅谈网络营销推广策略-方式方法利用
  9. python可以自动拆分表格吗_如何利用Python一键拆分表格并进行邮件发送~
  10. Jmeter报错Couldn‘t save test plan to file