洛谷 P9518 queue
一眼模拟。
需要维护的东西可以根据操作求得:
- start:正在玩游戏的 \(1\) 或 \(2\) 个人;
- arrive:当前在排队但没玩游戏的队列、每个人是否在排队、游玩;
- leave:每个人是否在排队、游玩。
如何维护
正在玩游戏的人:
我们使用 \(p_1\)、\(p_2\) 两变量存储,优先保证 \(p_1\) 有值,当 \(p_1\) 为空时上一轮无人游玩,\(p_2\) 为空时上一轮仅有一人游玩。
tips:由于优先保证 \(p_1\) 有值,故 \(p_2\) 为空时 \(p_1\) 非空。
当前在排队但没玩游戏的队列:
用数组模拟队列并惰性删除即可。
tips:将正在玩游戏的人放到队首,并在玩完游戏后将其放到队尾,只用维护一个“队列”即可。
每个人是否在排队、游玩:
用 map 映射名字到队列中的位置即可(tips:为什么不映射 bool,在这个讨论帖里说的已经很明白了)。
要定义的东西如下:
const int Maxn = 1e6 + 7;
int Q, l = 1, r = 1, len;
string q[Maxn], p1, p2;
map <string, int> m;
操作中的细节
start
只要队列里有人,游戏就能进行。因为根据题意描述,若只有 A 在游戏且无人排队、A 可在结束游戏后成为队首并加入下一轮游戏,故队列无人时输出 Error。
否则,将上一轮游玩的人放回队尾,并取出这一轮游玩的人(\(\geq 1\),想一想,为什么),将其名字输出。
具体实现如下:
if(opt == "start") {
p1 = p2 = "";
while(l < r && len) {
while(l < r && m[q[l]] != l) ++l;
if(l < r)
m[q[l]] = r, q[r++] = q[l], ++l;
--len;
}
while(l < r && m[q[l]] != l)
++l;
if(l == r) {
puts("Error");
continue;
}
p1 = q[l];
cout << p1;
++len;
int pos = l + 1;
while(pos < r && m[q[pos]] != pos)
++pos;
if(pos < r)
p2 = q[pos], cout << ' ' << p2, ++len;
puts("");
}
arrive
没什么好说的,看代码:
if(opt == "arrive") {
cin >> t;
if(m[t])
puts("Error");
else
q[r++] = t, m[t] = r - 1, puts("OK");
}
leave
若 x 在队列里且 x 不为玩家,x 可以离队;否则不能。
if (opt == "leave") {
cin >> t;
if(m[t] && t != p1 && t != p2)
m[t] = 0, puts("OK");
else
puts("Error");
}
Warning
考场并没有卡暴力 \(O(n)\) 删除的做法,但考试结束后同机房的 @幻想繁星 就申请加了 hack 数据(试图卡掉时的讨论帖、hack 数据)
Talk is cheap, show you the code.
#include <bits/stdc++.h>
using namespace std;
const int Maxn = 1e6 + 7;
int Q, l = 1, r = 1, len;
string q[Maxn], p1, p2;
map <string, int> m;
int main() {
ios::sync_with_stdio(false); cin.tie(0), cout.tie(0);
cin >> Q;
string opt, t;
while(Q--) {
cin >> opt;
if(opt == "start") {
p1 = p2 = "";
while(l < r && len) {
while(l < r && m[q[l]] != l) ++l;
if(l < r)
m[q[l]] = r, q[r++] = q[l], ++l;
--len;
}
while(l < r && m[q[l]] != l)
++l;
if(l == r) {
puts("Error");
continue;
}
p1 = q[l];
cout << p1;
++len;
int pos = l + 1;
while(pos < r && m[q[pos]] != pos)
++pos;
if(pos < r)
p2 = q[pos], cout << ' ' << p2, ++len;
puts("");
}
else if(opt == "arrive") {
cin >> t;
if(m[t])
puts("Error");
else
q[r++] = t, m[t] = r - 1, puts("OK");
}
else {
cin >> t;
if(p1 == t || p2 == t || !m[t])
puts("Error");
else
m[t] = 0, puts("OK");
}
}
return 0;
}
洛谷 P9518 queue的更多相关文章
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1710 地铁涨价
P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交 讨论 题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...
- 洛谷OJ P1196 银河英雄传说(带权并查集)
题目描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦 创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山 ...
- 洛谷P1519 穿越栅栏 Overfencing
P1519 穿越栅栏 Overfencing 69通过 275提交 题目提供者该用户不存在 标签USACO 难度普及/提高- 提交 讨论 题解 最新讨论 USACO是100分,洛谷是20分 为什么 ...
- 洛谷P1238 走迷宫
洛谷1238 走迷宫 题目描述 有一个m*n格的迷宫(表示有m行.n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点.结束点(起始点和结束点都是用两个 ...
- 洛谷P1189 逃跑的拉尔夫(SEARCH)
洛谷1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的 ...
- 洛谷P1126 机器人搬重物
洛谷1126 机器人搬重物 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格, ...
- 洛谷P1117 棋盘游戏
洛谷1117 棋盘游戏 题目描述 在一个4*4的棋盘上有8个黑棋和8个白棋,当且仅当两个格子有公共边,这两个格子上的棋是相邻的.移动棋子的规则是交换相邻两个棋子.现在给出一个初始棋盘和一个最终棋盘,要 ...
- 洛谷1001 A+B Problem
洛谷1001 A+B Problem 本题地址:http://www.luogu.org/problem/show?pid=1001 题目描述 输入两个整数a,b,输出它们的和(|a|,|b|< ...
- 洛谷P1962 斐波那契数列【矩阵运算】
洛谷P1962 斐波那契数列[矩阵运算] 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) ( ...
随机推荐
- Self-Instruct 论文解读:利用大模型自己给自己生成指令数据,指令数据自动生成
总览 大规模"指令调整"的语言模型,即指令微调的LLM,已经表现出非凡的零样本能力,尤其是推广新任务上. 然而,这些模型严重依赖于人类编写的指令数据,而这些数据通常在数量.多样性和 ...
- 2023-07-04:给定一个数组A, 把它分成两个数组B和C 对于数组A每个i位置的数来说, A[i] = B[i] + C[i] 也就是一个数字分成两份,然后各自进入B和C 要求B[i], C[i
2023-07-04:给定一个数组A, 把它分成两个数组B和C 对于数组A每个i位置的数来说, A[i] = B[i] + C[i] 也就是一个数字分成两份,然后各自进入B和C 要求B[i], C[i ...
- Unity 4.6 bate 20 or 4.5.5 +vuforia3.0.9 发布到真机错误 解决
错误图 +错误码 014-11-20 15:45:49.224 youzheng[6527:1035587] ################### enable 32014-11-20 15:45: ...
- 配置k8s拉取Harbor镜像
创建Secret # 认证名称为:docker-harbor-registry kubectl create secret docker-registry docker-harbor-registry ...
- 即构SDK8月迭代:新增下行网络测速、切换房间、预览首帧回调等多项功能
即构SDK8月上新,网络探测模块新增下行网络测速.媒体播放器新增缓存到文件结尾的回调.新增切换房间功能.新增预览首帧回调等.本月SDK迭代新上线的功能非常丰富,详细内容请看下文. LiveRoom 新 ...
- Day03_Java_作业
A:选择题 1.给出以下代码,请问表达式grade==70在以下两条语句中是否获得执行? boolean flag = false && grade == 70;//第一条语句 boo ...
- PWM点灯
目录 PWM脉冲宽调点灯 前言 1.什么是PWM 2.PWM的实现 3.PWM实现步骤(通用定时器) 3.1 打开定时器的时钟 3.2 配置端口 3.3 设置定时器 3.4 设置PWM 3.5 完整代 ...
- java文件共享实现方案
写在前面,由于项目要求负载,又不想大动干戈采用比较贵的设备和高大上的框架,经过一番研究,想使用文件共享方式实现文件的跨服务器访问.本方案采用了jcifs和smbj框架,若想用,请自行查找资源.此为初步 ...
- 安装deb包
输入命令: sudo dpkg -i file.deb
- 钟表练习 html+css实现
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...