Cod sursa(job #1790718)

Utilizator rares1012Rares Cautis rares1012 Data 28 octombrie 2016 17:25:42
Problema Carnati Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.9 kb
#include <cstdio>
#include <algorithm>

struct Client
{
    int timp;
    int pret;
};

Client v[2000];
bool cmp(Client a, Client b)
{
    return a.timp<b.timp;
}

int main()
{
    int n,k,i,s,inc,maxp=-100000,j;
    FILE*fi,*fo;
    fi=fopen("carnati.in","r");
    fo=fopen("carnati.out","w");
    fscanf(fi,"%d%d",&n,&k);
    for(i=0; i<n; i++)
        fscanf(fi,"%d%d",&v[i].timp,&v[i].pret);
    std::sort(v,v+n,cmp);
    maxp=0;
    for(i=0; i<n; i++)
    {
        s=1;
        inc=v[i].timp;
        for(j=0;j<n;j++)
        {
            if(s<0)
            {
                s=1;
                inc=v[i].timp;
            }
            if(v[j].pret>=v[i].pret)
                s+=v[i].pret;
            s=s-((v[j].timp-inc)*k);
            if(s>maxp)
                maxp=s;
        }
    }
    fprintf(fo,"%d",maxp);
    fclose(fi);
    fclose(fo);
    return 0;
}