Cod sursa(job #1525716)

Utilizator VictoriaNevTascau Victoria VictoriaNev Data 15 noiembrie 2015 14:36:51
Problema Heavy metal Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.75 kb
#include <fstream>
#include <algorithm>
using namespace std;
const int NMAX=100001;
int n, i, l, r, pos, d[NMAX];
struct sp
{
    int a, b;
} v[NMAX];
inline bool cmp(sp x, sp y)
{
    return x.b<y.b;
}
int main()
{
    ifstream in("input.in");
    ofstream out("output.out");
    in>>n;
    for(i=1; i<=n; i++)
        in>>v[i].a>>v[i].b;
    sort(v+1, v+n+1, cmp);
    for(i=1; i<=n; i++)
    {
        l=1;
        r=i-1;
        pos=0;
        while(l<=r)
        {
            int mid=(l+r)/2;
            if(v[mid].b<=v[i].a)
            {
                l=mid+1;
                pos=mid;
            }
            else
                r=mid-1;
        }out<<pos<<' ';
        d[i]=max(d[i-1], d[pos]+v[i].b-v[i].a);
    }
    out<<d[n]<<'\n';
    return 0;
}