Pagini recente » Cod sursa (job #1243146) | Cod sursa (job #1968804) | Cod sursa (job #913352) | Cod sursa (job #2472168) | Cod sursa (job #330074)
Cod sursa(job #330074)
/*#include<fstream>
#include<algorithm>
#define MaxN 50005
using namespace std;
ifstream fin("orase.in");
ofstream fout("orase.out");
struct casa {
int l,d;
};
casa v[MaxN];
int i,j=1,n,m,D,dis;
int cmp(casa a, casa b)
{ if(a.d==b.d)return a.l<b.l;
return a.d<b.d;}
int main()
{ fin>>m>>n;
for(i=1;i<=n;i++)
fin>>v[i].d>>v[i].l;
sort(v+1,v+1+n,cmp);
dis=v[1].l-v[1].d;j=1;
for(i=2;i<=n;i++)
{ if(v[i].l+v[i].d+v[j].l-v[j].d>D) D=v[i].l+v[i].d+dis;
if(v[i].l-v[i].d>dis)
{ dis=v[i].l-v[i].d;j=i;}
}
fout<<D<<'\n';
return 0;
}
*/
#include<fstream>
#include<algorithm>
using namespace std;
struct casa {int l,d;};
int cmp(casa a,casa b)
{if(a.d==b.d)
return a.l<b.l;
return a.d<b.d;}
int main()
{long long dn,dt,i,n,m,max=0,maxt=0;
casa v[50001];
ifstream q("orase.in");
ofstream w("orase.out");
q>>m>>n;
for(i=1;i<=n;i++)
q>>v[i].d>>v[i].l;
sort(v+1,v+n+1,cmp);
dt=v[1].l-v[1].d;
for(i=2;i<=n;i++)
{max=0;
dn=v[i].l-v[i].d;
if(dn<dt)
max=v[i].d+v[i].l+dt;
else
{max=v[i].d+v[i].l+dn;
dt=dn;}
if(maxt<max)
maxt=max;}
w<<maxt;
return 0;}