Cod sursa(job #330453)
| Utilizator | Data | 10 iulie 2009 01:08:58 | |
|---|---|---|---|
| Problema | Heapuri | Scor | 10 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 1.05 kb |
#include <set>
#include <stdio.h>
#define nmax 200001
using namespace std;
set<int> heap;
int nrnum,ndo[nmax];
int main()
{freopen("heapuri.in","r",stdin);freopen("heapuri.out","w",stdout);
int i,n,tip,x;
scanf("%d",&n);
for(i=1;i<=n;i++)
{scanf("%d",&tip);
if(tip==3) printf("%d\n",*heap.begin());
else {scanf("%d",&x);
if(tip==1) {heap.insert(x);
ndo[++nrnum]=x;
}
else heap.erase(heap.find(ndo[x]));
}
}
return 0;
}
