题目链接

题目

题目描述

最近吃鸡游戏非常火,你们wyh学长也在玩这款游戏,这款游戏有一个非常重要的过程,就是要跑到安全区内,否则就会中毒持续消耗血量,我们这个问题简化如下

假设地图为n*n的一个图,图中有且仅有一块X的联通快代表安全区域,有一个起点S代表缩圈的时候的起点,图中C代表的是车(保证车的数量小于等于100),标记为.的代表空地,可以任意通过,O代表障碍物不能通过。每次没有车的时候2s可以走一个格(只能走自己的上下左右4个方向),有车的话时间为1s走一个格

现在告诉你最多能坚持的时间为t秒,问你在t秒内(含t秒)能否从s点到达安全区域,能的话输出YES,并且输出最短时间,不能的话输出NO

输入描述

输入第一行一个整数T(1<=T<=10)

接下来有T组测试数据,每组测试数据输入2个数n和k(1<=n<=100,1<=k<=10^9)

接下来n行,每行n个字符,代表对应的n*n的地图,每个字符都是上面的一种,并且保证只有一个起点,只有一块安全区域。

输出描述

对于每组测试数据,先输出能否到达,能的话输出YES,然后换行输出最短时间,如果不能的话直接输出NO

示例1

输入

3
2 3
.X
S.
2 3
.X
SC
2 4
.X
S.

输出

NO
YES
3
YES
4

题解

方法一

知识点:BFS,优先队列。

因为车的花费和走路花费不一致,会导致时间线混乱,因此可以考虑用优先队列维护时间线扩展,使得每次都是扩展最短时间的点,维持有序性。

同时,因为车的状态是持续的,非一次性的,因此状态需要多一维记录是否有车。

细节上,因为车的状态带来的花费影响是下一步才开始,不像传送门是即刻的,因此可以在扩展后直接锁点。

时间复杂度 \(O(?)\)

空间复杂度 \(O(nm)\)

方法二

知识点:BFS。

高维状态和方法一一样,但不使用优先队列维护时间线有序,因此锁点操作通过步数实现。如果当前扩展的步数小于扩展到点的历史步数,那就用本次步数覆盖这个状态的步数。注意要遍历完全才能得出答案。

时间复杂度 \(O(?)\)

空间复杂度 \(O(nm)\)

代码

方法一

#include <bits/stdc++.h>
#define ll long long using namespace std; int n, t;
char dt[107][107];
bool vis[107][107][2];
const int dir[4][2] = { {1,0},{-1,0},{0,1}, { 0,-1 } }; struct node {
int x;
int y;
bool c;
int step;
friend bool operator<(const node &a, const node &b) {
return a.step > b.step;
}
}; int bfs(node st) {
priority_queue<node> pq;
pq.push(st);
vis[st.x][st.y][st.c] = 1;
while (!pq.empty()) {
node cur = pq.top();
pq.pop();
if (dt[cur.x][cur.y] == 'X') return cur.step;
for (int i = 0;i < 4;i++) {
int xx = cur.x + dir[i][0];
int yy = cur.y + dir[i][1];
bool cc = cur.c || dt[xx][yy] == 'C';
int sstep = cur.step + (cur.c ? 1 : 2);///和之前一次有关
if (xx < 0 || xx >= n || yy < 0 || yy >= n || vis[xx][yy][cc] || dt[xx][yy] == 'O' || sstep > t)continue;
vis[xx][yy][cc] = 1;///因为不是在这次就改变时间线,所以依旧可以在扩展时直接锁定点
pq.push({ xx,yy,cc,sstep });
}
}
return 1e9 + 10;
} bool solve() {
cin >> n >> t;
node st;
for (int i = 0;i < n;i++) {
for (int j = 0;j < n;j++) {
cin >> dt[i][j];
if (dt[i][j] == 'S') st.x = i, st.y = j, st.c = 0, st.step = 0;
vis[i][j][0] = vis[i][j][1] = 0;
}
}
int ans = bfs(st);
if (ans > t) return false;
else cout << "YES\n" << ans << '\n';
return true;
} int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << "NO" << '\n';
}
return 0;
}

方法二

#include <bits/stdc++.h>
#define ll long long using namespace std; int n, t;
char dt[107][107];
int step[107][107][2];
const int dir[4][2] = { {1,0},{-1,0},{0,1}, { 0,-1 } }; struct node {
int x, y;
bool c;
}; int bfs(node st, vector<node> &ed) {
queue<node> q;
q.push(st);
step[st.x][st.y][0] = 0;
while (!q.empty()) {
node cur = q.front();
q.pop();
if (dt[cur.x][cur.y] == 'X') continue;
for (int i = 0;i < 4;i++) {
int xx = cur.x + dir[i][0];
int yy = cur.y + dir[i][1];
int delta = cur.c ? 1 : 2;
if (xx < 0 || xx >= n || yy < 0 || yy >= n || dt[xx][yy] == 'O')continue;
bool cc = cur.c || dt[xx][yy] == 'C';
if (step[xx][yy][cc] <= step[cur.x][cur.y][cur.c] + delta) continue;
///不能用vis锁定点,因为扩展时间线混乱,不按照时间顺序扩展
///有可能时间晚的车先占了格子,早的车没扩展过来就无法覆盖了,因此只能用距离覆盖
step[xx][yy][cc] = step[cur.x][cur.y][cur.c] + delta;
q.push({ xx,yy,cc });
}
}
int ans = 1e9;
for (auto e : ed) ans = min({ ans, step[e.x][e.y][0],step[e.x][e.y][1] });///目的地是个连通块
return ans;
} bool solve() {
cin >> n >> t;
node st;
vector<node> ed;
for (int i = 0;i < n;i++) {
for (int j = 0;j < n;j++) {
cin >> dt[i][j];
if (dt[i][j] == 'S') st.x = i, st.y = j, st.c = 0;
if (dt[i][j] == 'X') ed.push_back({ i,j,0 });
step[i][j][0] = step[i][j][1] = 1e9;
}
}
int ans = bfs(st, ed);
if (ans > t) return false;
else cout << "YES\n" << ans << '\n';
return true;
} int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
if (!solve()) cout << "NO" << '\n';
}
return 0;
}

NC15445 wyh的吃鸡的更多相关文章

  1. 2018年东北农业大学春季校赛-wyh的吃鸡

    BFS: 1. 从起点开始BFS,遇到X点则return: 2. vis[px][py][0]代表经过pxpy这点前还没有找到车: vis[px][py][1]代表经过pxpy这点前已经找到车: 3. ...

  2. newcode wyh的吃鸡(优势队列+BFS)题解

    思路: 要用优势队列,因为有的+2,有的+1,所以队列中的步长是不单调的,所以找到一个答案但不一定最小,所以用优势队列把小的放在队首. 要记录状态,所以开了三维,题目和昨天做的那道小明差不多 vis开 ...

  3. 为什么MOBA、“吃鸡”游戏不推荐用tcp协议——实测数据

    欢迎大家前往云加社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯云游戏行业资深架构师 余国良 MOBA类和"吃鸡"游戏为什么对网络延迟要求高? 我们知道,不同类型的游戏因为玩法. ...

  4. 3D位置语音,引领吃鸡游戏体验升级

    欢迎大家前往云加社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯游戏云 导语:在刚刚结束的首届腾讯用户开放日上,腾讯音视频实验室带着3D位置音效解决方案,向所有用户亮相,为用户提供360度立体空间的 ...

  5. 【程序员的吃鸡大法】利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏

    [先上一张效果图]: 一.原理: 其实原理很简单: 1.手机投屏到电脑: 2.截取投屏画面的题目部分,进行识别,得到题目和三个答案: 3.将答案按照一定的算法,进行搜索,得出推荐答案: 4.添加了一些 ...

  6. tcp没用吗?为什么MOBA、“吃鸡”游戏不推荐用tcp协议

    本文由云+社区发表 作者:腾讯云游戏行业资深架构师 余国良 MOBA类和"吃鸡"游戏为什么对网络延迟要求高? 我们知道,不同类型的游戏因为玩法.竞技程度不一样,采用的同步算法不一样 ...

  7. GMA Round 1 大吉大利,晚上吃鸡

    传送门 大吉大利,晚上吃鸡 新年走亲访友能干点啥呢,咱开黑吃鸡吧. 这里有32个人,每个人都可能想玩或者不想玩,这样子一共有$2^{32}$种可能.而要开黑当然得4人4人组一队(四人模式),所以说如果 ...

  8. 多校寒训TaoTao要吃鸡dp

    题目描述 Taotao的电脑带不动绝地求生,所以taotao只能去玩pc版的荒野行动了, 和绝地求生一样,游戏人物本身可以携带一定重量m的物品,装备背包 之后可以多携带h(h为0代表没有装备背包)重量 ...

  9. 伪装为 吃鸡账号获取器 的QQ木马分析

    本文作者:i春秋作家坏猫叔叔 0×01 起因随着吃鸡热潮的来临,各种各样的吃鸡辅助和账号交易也在互联网的灰色地带迅速繁殖滋生.其中有真有假,也不乏心怀鬼胎的“放马人”.吃过晚饭后在一个论坛看到了这样一 ...

  10. 2018年全国多校算法寒假训练营练习比赛(第二场)B - TaoTao要吃鸡

    链接:https://www.nowcoder.com/acm/contest/74/B来源:牛客网 题目描述 Taotao的电脑带不动绝地求生,所以taotao只能去玩pc版的荒野行动了, 和绝地求 ...

随机推荐

  1. Linux复制安装 jdk 环境

    转载请注明出处: 最近在弄服务器环境,发现可以通过复制已安装 jdk 的服务器配置到新的服务器,并配置服务器环境变量配置文件就可以完成. 操作步骤如下: 1. 查看以安装jdk服务器的环境配置,并复制 ...

  2. JavaScript 对象和 JSON 的区别

    参考原文:https://blog.csdn.net/jiaojiao772992/article/details/77871785/ 2.1 对象和 JSON 的区别 JSON 就是 JavaScr ...

  3. Laravel - 使用查询构造器查询

    public function constructorQuery()     {         # 1,新增         DB::table('student')->insert([    ...

  4. HttpClient获取不到最新的系统代理

    默认情况下,HttpClient是默认采用系统代理,但是,如果你在程序运行过程中,手动修改系统代理,对于HttpClient是无效的,它依然会用老的代理去访问. 解决方法 使用下面的代码,你可以自己实 ...

  5. 百度网盘(百度云)SVIP超级会员共享账号每日更新(2023.12.26)

    一.百度网盘SVIP超级会员共享账号 可能很多人不懂这个共享账号是什么意思,小编在这里给大家做一下解答. 我们多知道百度网盘很大的用处就是类似U盘,不同的人把文件上传到百度网盘,别人可以直接下载,避免 ...

  6. 面试官:小伙子来说一说Java中final关键字,以及它和finally、finalize()有什么区别?

    写在开头 面试官:"小伙子,用过final关键字吗?" 我:"必须用过呀" 面试官:"好,那来说一说你对这个关键字的理解吧,再说一说它与finally ...

  7. [转帖]goproxy 使用说明

    Go 版本要求 建议您使用 Go 1.13 及以上版本, 可以在这里下载最新的 Go 稳定版本. 配置 Goproxy 环境变量 Bash (Linux or macOS) export GOPROX ...

  8. [转帖]【软件测试】Jmeter性能测试(性能测试,Jmeter使用与结果分析)

    文章目录 前言 一.性能测试 1. 什么是性能测试? 2. 性能测试的重要性 3. 性能指标--QPS和TPS ①QPS ②TPS 二.压测工具Jmeter 1. 什么是Jmeter? 2. Jmet ...

  9. [转帖]Linux—vi/vim批量注释及取消注释

    https://www.jianshu.com/p/45c252e9d2b6 应用场景   在开发场景中,经常遇到对一些配置文件进行注释,当然如果确定不用的时候我们可以通过vim中的D命令进行删除.当 ...

  10. [转帖]总结:记一次K8S容器OOM案例

    一.背景 最近遇到个现象,hubble-api-open组件过段时间会内容占满,从而被K8S强制重启. 让我困惑的是,已经设置了-XX:MaxRAMPercentage=75.0,我觉得留有了一定的空 ...