Cod sursa(job #484412)

Utilizator dushmiMihai-Alexandru Dusmanu dushmi Data 14 septembrie 2010 02:13:43
Problema Heavy metal Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.27 kb
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
vector<int> in[1<<18];
int q,MAX,n,din[1<<18],v[1<<18],norm[1<<18],lung[1<<17],a[1<<17],b[1<<17];
void read()
{
    freopen("heavymetal.in","r",stdin);
    freopen("heavymetal.out","w",stdout);
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        scanf("%d%d",&a[i],&b[i]);
        v[++q]=a[i];
        v[++q]=b[i];
    }
}
int cautb(int x)
{
    int pas=1<<17,i=0;
    for(i=0;pas;pas>>=1)
        if(v[i+pas]<x && i+pas<=q)
            i+=pas;
    return i;
}
void normalizare()
{
    int nr=0;
    sort(v+1,v+q+1);
    for(int i=1;i<=q;i++)
        if(v[i]!=v[i-1])
            norm[i]=++nr;
    MAX=nr;
    for(int i=1;i<=n;i++)
    {
        lung[i]=b[i]-a[i];
        a[i]=norm[cautb(a[i])+1];
        b[i]=norm[cautb(b[i])+1];
    }
    for(int i=1;i<=n;i++)
        in[b[i]].push_back(i);
}
int maxim(int x,int y)
{
    return x<y?y:x;
}
void solve()
{
    for(int i=1;i<=MAX;i++)
    {
        din[i]=din[i-1];
        for(vector<int>::iterator it=in[i].begin();it!=in[i].end();it++)
            din[i]=maxim(din[i],din[a[*it]]+lung[*it]);
    }
    printf("%d",din[MAX]);
}
int main()
{
    read();
    normalizare();
    solve();
    return 0;
}