Cod sursa(job #2055673)

Utilizator ContDeRacistAliniateEBlat ContDeRacist Data 3 noiembrie 2017 16:29:10
Problema Branza Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.63 kb
#include <fstream>

using namespace std;

ifstream cin("branza.in");
ofstream cout("branza.out");

const int N = 100000;

pair < int, int > v[N];
int d[N];

int main()
{
    int n, s, t, st = 0, dr = -1;
    long long sum = 0;
    cin >> n >> s >> t;
    for (int i = 0; i < n; ++i) {
        cin >> v[i].first >> v[i].second;
        while(st <= dr && d[st] == i - t) {
            ++st;
        }
        while(st <= dr && 1LL * (v[d[dr]].first + s * (i - d[dr])) >= v[i].first) {
            --dr;
        }
        d[++dr] = i;
            sum += 1LL * (v[d[st]].first + s * (i - d[st])) * v[i].second;
    }
    cout << sum;
    return 0;
}