NC17889 新建 Microsoft Office Word 文档
题目
题目描述
CSL正在学习《计算机办公自动化》文件的建立与删除。
CSL发现,当他新建一个word文档时,会得到一个名为"新建 Microsoft Office Word 文档.doc"的文件,再新建一个,则名为"新建 Microsoft Office Word 文档(2).doc",再新建,便是"新建 Microsoft Office Word 文档(3).doc"。不断新建,编号不断递增。倘若他已经新建了三个文档,然后删除了"新建 Microsoft Office Word 文档(2).doc",再新建一个就又会得到一个"新建 Microsoft Office Word 文档(2).doc"。
严格来说,Windows在每次新建文档时,都会选取一个与已有文件编号不重复的最小正整数作为新文档的编号。
现在,请你编程模拟以上过程,支持以下两种操作:
New:新建一个word文档,反馈新建的文档的编号;
Delete id:删除一个编号为id的word文档,反馈删除是否成功。
初始时一个文件都没有,"新建 Microsoft Office Word 文档.doc"的编号算作1。
输入描述
第一行一个正整数n表示操作次数,接下来n行,每行表示一个操作。若该行为"New",则表示新建,为:Delete id"则表示要删除编号为id的文档,其中id为一个正整数。操作按输入顺序依次进行。操作次数不超过100000,删除编号的数值不超过100000。
输出描述
对于输入的每一个操作,输出其反馈结果。对于新建操作,输出新建的文档的编号;对于删除操作,反馈删除是否成功:如果删除的文件存在,则删除成功,输出"Successful",否则输出"Failed"。
示例1
输入
12
New
New
New
Delete 2
New
Delete 4
Delete 3
Delete 1
New
New
New
Delete 4
输出
1
2
3
Successful
2
Failed
Successful
Successful
1
3
4
Successful
题解
知识点:STL,模拟,优先队列。
简单但不是完全简单的模拟。
用一个优先队列记录当前空缺编号的从小到大排列,方便新建时候找到最小的空缺编号。
用一个变量记录当前最大文件编号,方便 failed
的判断。
用一个布尔数组记录当前编号的空缺状态,方便 failed
的判断。
时间复杂度 \(O(n \log n)\)
空间复杂度 \(O(n)\)
代码
#include <bits/stdc++.h>
using namespace std;
bool vis[100007];
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int n;
cin >> n;
priority_queue<int, vector<int>, greater<int>> pq;
int pos = 0;
while (n--) {
string op;
cin >> op;
if (op == "New") {
if (pq.empty()) cout << ++pos << '\n';
else vis[pq.top()] = 0, cout << pq.top() << '\n', pq.pop();
}
else if (op == "Delete") {
int x;
cin >> x;
if (vis[x] || x > pos) cout << "Failed" << '\n';
else {
vis[x] = 1;
pq.push(x);
cout << "Successful" << '\n';
}
}
}
return 0;
}
本文来自博客园,作者:空白菌,转载请注明原文链接:https://www.cnblogs.com/BlankYang/p/16461239.html