Pagini recente » Cod sursa (job #1098474) | Cod sursa (job #101735) | Cod sursa (job #2973892) | Cod sursa (job #2257849) | Cod sursa (job #155476)
Cod sursa(job #155476)
#include <stdio.h>
struct ggg
{
long t,p;
};
typedef struct ggg pozis;
pozis a[2010];
long N,nr;
long S,k,suma[2010],K;
void citire()
{
freopen ("carnati.in","r",stdin);
scanf("%ld %ld",&N,&K);
for (int i=0;i<N;i++)
scanf("%ld%ld",&a[i].t,&a[i].p);
fclose(stdout);
}
void maxim()
{
long maxim=0;
for (int i=0;i<N;i++)
{
long S=0,poz=0,ok=0;
for (int k=0;k<N;k++)
{
if (ok==0)
{
if (a[k].p>=a[i].p )
{
ok=1;
S=a[i].p;
poz=a[k].t;
}
}
else
{
if (a[k].p>=a[i].p)
{
S+=a[i].p;
}
}
if (S-(a[k].t-poz+1)*K<=0)
{
S=0;
ok=0;
poz=a[k].t;
}
else
if (S-(a[k].t-poz+1)*K>maxim)
maxim=S-(a[k].t-poz+1)*K;
}
}
freopen ("carnati.out","w",stdout);
printf ("%ld\n",maxim);
fclose (stdout);
}
int main ()
{
citire();
maxim();
return 0;
}