Cod sursa(job #429487)
| Utilizator | Data | 30 martie 2010 10:58:48 | |
|---|---|---|---|
| Problema | Heapuri | Scor | 40 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.5 kb |
#include<stdio.h>
#include<set>
using namespace std;
int n,i,x,nr,a[200200];
int op;
FILE *f,*g;
int main()
{ f=fopen("heapuri.in","r"); g=fopen("heapuri.out","w");
fscanf(f,"%d",&n);
multiset<int>myset;
for(i=1;i<=n;i++)
{ fscanf(f,"%d",&op);
if(op==1) { fscanf(f,"%d",&x); myset.insert(x); nr++; a[nr]=x; }
else if(op==2) { fscanf(f,"%d",&x); myset.erase(a[x]); }
else { multiset <int> :: iterator it = myset.begin(); fprintf(g,"%d\n",*it); }
}
fclose(g);
return 0;
}
