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