Cod sursa(job #2085124)

Utilizator DeleDelegeanu Alexandru Dele Data 9 decembrie 2017 18:44:32
Problema Heapuri Scor 40
Compilator cpp Status done
Runda Arhiva educationala Marime 1.23 kb
#include<fstream>
using namespace std;
ifstream f("heapuri.in");
ofstream g("heapuri.out");
int n,m,i,j,k,p,cod,H[200001],poz[200001];
void push_up(int x)
{
    int val;
    val=H[x];
    while(x>1&&val<H[x/2])
    {
        H[x]=H[x/2];
        x/=2;
    }
    H[x]=val;
}
void push_down(int x)
{
    int son;
    do
    {
        son=0;
        if(x<=m)
        {
            son=x*2;
            if(x*2+1<=m && H[x*2+1]<H[x*2])
                son=x*2+1;
            if(H[son]<=H[x])
                son=0;
        }
        if(son)
        {
            swap(H[son],H[x]);
            x=son;
        }
    }
    while(son);
}
int main()
{
    f>>n;
    for(i=1 ; i<=n ; ++i)
    {
        f>>cod;
        if(cod==1)
        {
            f>>k;
            H[++m]=k;
            poz[++p]=k;
            push_up(m);
        }
        else
            if(cod==2)
            {
                f>>k;
                for(j=1;j<=m;++j)
                    if(H[j]==poz[k])
                    {
                        push_down(j);
                        break;
                    }
                --m;
            }
            else
                g<<H[1]<<'\n';
    }
    return 0;
}