Pagini recente » Cod sursa (job #386822) | Cod sursa (job #2711250) | Cod sursa (job #2840511) | Cod sursa (job #405107) | Cod sursa (job #155547)
Cod sursa(job #155547)
#include <stdio.h>
struct ggg
{
long t,p;
};
typedef struct ggg pozis;
pozis a[5010];
long N,nr;
long S,k,suma[5010],K;
void citire()
{
freopen ("carnati.in","r",stdin);
scanf("%ld %ld",&N,&K);
for (int i=1;i<=N;i++)
scanf("%ld%ld",&a[i].t,&a[i].p);
fclose(stdout);
}
void maxim()
{
long maxim=0;
for (int i=1;i<=N;i++)
{
long S=0,poz=0,ok=0;
for (int k=1;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-(a[k].t-poz+1)*K<=0)
{
S=0;
ok=0;
poz=0;
}
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);
}
void bule ()
{
int p=N,ok=1;
while (ok)
{
ok=0;
p--;
for (int i=1;i<=p;i++)
if (a[i].t>a[i+1].t)
{
pozis aux=a[i];
a[i]=a[i+1];
a[i+1]=aux;
ok=1;
}
}
}
int main ()
{
citire();
bule();
maxim();
return 0;
}