Pagini recente » Diferente pentru problema/deque intre reviziile 7 si 6 | Cod sursa (job #3330403) | Cod sursa (job #2858740) | Cod sursa (job #2152606) | Cod sursa (job #3329985)
#include <fstream>
#include <deque>
using namespace std;
ifstream cin("deque.in");
ofstream cout("deque.out");
struct numar{
int vl, poz;
};
numar x;
int i, n, k, nr;
long long s;
int main()
{
deque<numar> md;
cin >> n >> k;
for(int i = 1; i <= n; i++)
{
cin >> nr;
while(!md.empty() && md.front().poz < i - k + 1)
{
md.pop_front();
}
while(!md.empty() && md.back().vl > nr)
{
md.pop_back();
}
x.vl = nr;
x.poz = i;
md.push_back(x);
if(i >= k)
{
s += md.front().vl;
}
}
cout << s << endl;
}