Cod sursa(job #330074)

Utilizator c_e_manuEmanuel Cinca c_e_manu Data 8 iulie 2009 16:10:10
Problema Orase Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.13 kb
/*#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;}