Cod sursa(job #2795965)

Utilizator toma_ariciuAriciu Toma toma_ariciu Data 7 noiembrie 2021 12:36:40
Problema Lupul Urias si Rau Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.88 kb

#include <iostream>
#include <fstream>
#include <queue>
#include <algorithm>

using namespace std;

ifstream fin("lupu.in");
ofstream fout("lupu.out");

struct oaie {
    long long dist, lana;
}v[100005];

long long n,x,l;
long long ans;
priority_queue <long long> heap;

bool cmp(oaie a, oaie b)
{
    return a.dist < b.dist;
}
void citire()
{
    fin>>n>>x>>l;
    for(long long i=1; i<=n; i++)
    {
        fin>>v[i].dist>>v[i].lana;
    }
}

void solve()
{
    sort(v+1, v+n+2, cmp);
    long long j=1;
    for(int i=0; i<=x; i=i+l)
    {
        while(j <= n && v[j].dist <= i)
        {
            heap.push(v[j].lana);
            j++;
        }
        if(!heap.empty())
        {
            ans=ans+heap.top();
            heap.pop();
        }
    }
    fout<<ans;
}

int main()
{
    citire();
    solve();
    return 0;
}