Cod sursa(job #2720987)

Utilizator Bogdan.paun50Mandresi Bogdan Bogdan.paun50 Data 11 martie 2021 14:33:16
Problema Heapuri Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.84 kb
#include <bits/stdc++.h>

using namespace std;

const int NMAX = 200010;

ifstream fin("heapuri.in");
ofstream fout("heapuri.out");

int n, q, val, k, ind, deleted[NMAX];

priority_queue<pair<int, int>> heap;

int main()
{
    fin >> n;
    for(int i = 1; i <= n; i++)
    {
        fin >> q;
        if(q==1)
        {
            fin >> val;
            k++;
            //pair<int, int> p;
            //p.first = -val;
            //p.second = k;
            //heap.push(p);
            heap.push(make_pair(-val, k));

        }
        else if (q == 2)
        {
            fin >> ind;
            deleted[ind] = 1;


        }
        else
        {
            while(deleted[heap.top().second])
                heap.pop();
            fout << -heap.top().first << "\n";
        }
    }
    return 0;
}