You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

72 lines
2.4 KiB

2 years ago
#include <bits/stdc++.h>
using namespace std;
const int N = 100010;
int h[N], sz; // 堆,堆中元素个数
int p[N]; // 输入序号 与 堆中序号映射关系 p[2]=3 表示第2个输入的在堆中序号是3号
int q[N]; // 堆中序号 与 输入序号映射关系 q[3]=2 表示堆中序号3号是第2个输入的
int n, idx; // n:指令数idx:输入序号
// 交换两个堆中的元素a,b是指堆中序号
void heap_swap(int a, int b) {
swap(h[a], h[b]); // 交换堆中序号a与序号b的元素值
swap(q[a], q[b]); // 输入序号交换
swap(p[q[a]], p[q[b]]); // 输入序号与堆中序号的映射关系
}
void down(int u) {
int t = u;
// 换到左右儿子和u的最小值
if (u * 2 <= sz && h[u * 2] < h[t]) t = u * 2;
if (u * 2 + 1 <= sz && h[u * 2 + 1] < h[t]) t = u * 2 + 1;
if (u != t) {
heap_swap(u, t);
down(t);
}
}
void up(int u) {
while (u / 2 && h[u] < h[u / 2]) { // 爹活着,比爹牛,上位!(玄武门事变?)
heap_swap(u, u / 2);
u /= 2;
}
}
int main() {
cin >> n;
while (n--) {
string op;
int k, x;
cin >> op;
if (op == "I") {
cin >> x;
p[++idx] = ++sz; // ① 第idx个插入的元素在堆中的序号是sz
q[sz] = idx; // ② 堆中sz号元素它是第idx个插入进来的
h[sz] = x; // ③ 堆中sz号元素的值为x
up(sz);
}
if (op == "PM") printf("%d\n", h[1]);
if (op == "DM") {
heap_swap(1, sz); // 用堆中最后一个元素替换掉1号元素
sz--; // 删除尾部元素
down(1); // 重排
}
if (op == "D") {
cin >> k; // 第k个输入序号
k = p[k]; // 获得堆中序号
heap_swap(sz, k); // 将第k个与最后一个交换
sz--; // 删除尾部元素
down(k); // down一下up一下
up(k);
}
if (op == "C") {
cin >> k >> x; // 第k个输入序号,修改值为x
k = p[k]; // 根据输入序号查找到堆中序号k
h[k] = x; // 将值修改为x
down(k); // down一下up一下
up(k);
}
}
return 0;
}