Pagini recente » Cod sursa (job #1760) | Cod sursa (job #1269079) | Cod sursa (job #1156976) | Cod sursa (job #306783) | Cod sursa (job #1972052)
#include<stdio.h>
#include<algorithm>
using namespace std;
struct VIBROCIL
{
int a,b;
};
int ans[1000005];
VIBROCIL v[100005];
int cmp(VIBROCIL &x,VIBROCIL &y)
{
if(x.b<y.b)
return 1;
if(x.b>y.b)
return 0;
if(x.a<y.a)
return 1;
return 0;
}
int main()
{
freopen("heavymetal.in","r",stdin);
freopen("heavymetal.out","w",stdout);
int n,i,x,j=0,aux;
scanf("%d",&n);
for(i=0; i<n; ++i)
scanf("%d%d",&v[i].a,&v[i].b);
sort(v,v+n,cmp);
x=v[n-1].b;
for(i=1; i<=x; ++i)
{
ans[i]=ans[i-1];
while(i==v[j].b)
{
aux=ans[v[j].a]+v[j].b-v[j].a;
if(aux>ans[i])
ans[i]=aux;
j++;
}
}
printf("%d\n",ans[x]);
return 0;
}