Pagini recente » Cod sursa (job #1526591) | Cod sursa (job #576917) | Cod sursa (job #299443) | Cod sursa (job #771324) | Cod sursa (job #484412)
Cod sursa(job #484412)
#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;
}