Cod sursa(job #2936966)
Utilizator | Data | 9 noiembrie 2022 18:25:50 | |
---|---|---|---|
Problema | Deque | Scor | 25 |
Compilator | cpp-64 | Status | done |
Runda | cnilc1_2-dq | Marime | 0.52 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int N, K, i, x, A[5000005], S;
deque<int> Deq;
int main()
{
f >> N >> K;
for(i = 1; i <= N; i ++)f >> A[i];
for(i = 1; i <= N; i ++)
{
while(!Deq.empty() && A[Deq.back()] >= A[i])Deq.pop_back();
Deq.push_back(i);
if(i >= K)
{
if(i - Deq.front() + 1 > K)Deq.pop_front();
S += A[Deq.front()];
}
}
g << S;
return 0;
}