Pagini recente » Cod sursa (job #2609525) | Cod sursa (job #277012) | Cod sursa (job #1603704) | Cod sursa (job #400463) | Cod sursa (job #3127371)
#include <iostream>
#include <fstream>
using namespace std;
int cantitate[10000001],pret[10000001],suma,k;
ifstream f ("branza.in");
ofstream g ("branza.out");
int main()
{
int N,S,T;
f>>N>>S>>T;
for(int i = 0; i <N; ++i)
f>>pret[i]>>cantitate[i];
for(int i = 0; i <N; ++i)
{
int mini=pret[i]*cantitate[i];
if(k && k>=i-T)
{
if(mini>pret[k]*cantitate[i]+cantitate[i]*(i-k)*S)
{
mini= pret[k]*cantitate[i]+cantitate[i]*(i-k)*S;
}
}
else
for(int j = i-1 ; j>=i-T && j>=0; j--)
{
if(mini>pret[j]*cantitate[i]+cantitate[i]*(i-j)*S)
{
mini= pret[j]*cantitate[i]+cantitate[i]*(i-j)*S;
k=j;
}
}
suma+=mini;
}
g<<suma;
}