22. 地下城与勇士
龙神觉得无聊于是来到了地下城,这里是一个巨大的迷宫,有一些可以通行的路、一些不可以通行的墙,还有一些怪物。虽然龙神可以轻易地干掉这些怪物,但他觉得这样就太没意思了,他观察到这些怪物每 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. 地下城与勇士相关推荐
- 连接黑屏_解决地下城与勇士PK服登录游戏卡在“正在连接服务器”的黑屏界面...
网吧安装好了地下城与勇士DNF比赛PK服,但总是进不去游戏,具体如下图: 一直卡在"正在连接服务器..."黑屏状态 首先显示隐藏文件和系统文件: 我们先找到存DNF.cfg这个文件 ...
- 使用模拟器玩地下城与勇士M电脑版试玩分享
<地下城与勇士 M>是采用2D横版格斗人气网游IP原作做的一款手游.游戏目前地下城与勇士 Neople 和 腾讯合作研发中,游戏中玩家看到无限连击的动作特性.极富多样化的职业分支.精准的操 ...
- DNF登陆的时候说连接服务器失败,请检查您的网络。是否启用修复程序进行修复?,地下城和勇士常见问题修复方法.doc...
地下城和勇士常见问题修复方法 日常问答 [未使用第三方软件被系统提示使用第三方软件] 解决方案:请到 HYPERLINK "/dnf/index_dnf.htm?t=dnf" \t ...
- 浅析《地下城与勇士:决斗》的卡通渲染
<地下城与勇士:决斗>罪恶装备和碧蓝幻想都是一家叫Arc System Works公司出品的,它们的渲染也是用的同一套思路.我们使用碧蓝幻想的游戏内的资源做一个解析. 模型使用了四张贴图: ...
- 怎么把字母缩小当符号_《DNF手游》名字特殊符号怎么打 地下城与勇士M特殊符号取名教学...
dnf手游名字特殊符号怎么打?在地下城与勇士M中,游戏中很多玩家想取个性化的昵称,加入合适的特殊符号是不错的选择,那么特殊符号怎么打,下面就来告诉大家,一起来看看吧. 地下城与勇士M特殊符号复制介绍 ...
- 地下城与勇士M如何用电脑玩 地下城与勇士M电脑版教程
<地下城与勇士M>是一款根据端游同款游戏改编而来的冒险挑战类手机游戏.在这个暗黑的世界之中,你需要化身为一个超级无比的勇士,你不仅仅需要拥有超级震撼的完美炫斗技能大招,简单畅爽的操作,带你 ...
- Java实现——地下城与勇士DNF武器强化(+0——+16)
Java实现--地下城与勇士DNF武器强化(+0--+16) DNF中强化装备能够为装备增加攻击力,从而增加角色的攻击力.强化的等级越高,增加的攻击越高,但强化装备有着一定的失败 1.运行样例 强化规 ...
- 地下城与勇士体验服不显示服务器,地下城与勇士M手游体验服进不去怎么办?内测问题与解决方案汇总[多图]...
腾讯官方<地下城与勇士M>手游的内测体验服已于2019年12月9日~10日正式开放下载.玩家们已经翘首以盼苦等一年,无论是否还在PC端阿拉德世界征战,听到手游小溪后都会第一时间申请资格并下 ...
- 地下城与勇士m服务器维护,地下城与勇士M怎么登不了 登陆不了解决办法
地下城与勇士M正式版v0.7.2.3 安卓版 类型:动作射击大小:129.5M语言:中文 评分:10.0 标签: 立即下载 地下城与勇士M正在测试中,玩家使用QQ或微信即可登陆游戏,不过有玩家进入游戏 ...
最新文章
- 学写jQuery插件开发方法
- 从新手到Flutter架构师,一篇就够!吐血整理
- Java项目案例大全
- [教程]添加yueue.ADOKeycap数据库组件到您的项目
- 一些值得注意的算法题——队列、栈
- 电子计算机第一代到第四代,从第一代电子计算机到第四代计算机的体系结构都是由运算器、控制器、存储器、输入设备和输出设备组成的,称为( )体系结构。...
- 推荐8个不错的视频自动加字幕工具
- 8T磁盘阵列文件存储服务器 威联通,NAS私有云老司机折腾体验记 篇八:QNAP 威联通TR-004磁盘阵列外接盒使用教程...
- 华为云CentOS7.6云耀服务器Python环境基本配置
- 算法创作|模拟商品加入购物车并结算价钱问题解决方法
- OPENCV scalar
- 天文学论文绘图注意事项
- java中 SSL认证和keystore使用
- 解决input 中 type=“number“右侧上下箭头以及取消默认滚轮事件
- navicat for mysql 模型_Navicat for MySQL 功能简介
- 坚果pro2s android 8,坚果Pro2s和小米8se哪个好?坚果Pro2s对比小米8se区别评测
- 知云文献翻译打不开_学用系列自带翻译功能的PDF文献阅读器——知云文献翻译3.0...
- Integer缓存IntegerCache详解
- 从菜鸟到高手,CMD命令行了解arp欺骗攻击的原理
- 以前管Facebook叫“脸书” 现在管Meta叫什么呢