Cod sursa(job #3126270)
| Utilizator | Data | 6 mai 2023 14:29:01 | |
|---|---|---|---|
| Problema | Deque | Scor | 60 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.6 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
const int NMAX = 5e6 + 5;
long long a[NMAX], dq[NMAX], n, k, st = 1, dr;
int main(){
f >> n >> k;
for(int i = 1; i <= n; ++i){
f >> a[i];
}
long long sol = 0;
for(int i = 1; i <= n; ++i){
while(st <= dr && dq[st] < i - k + 1){
st++;
}
while(st <= dr && a[i] <= a[dq[dr]]){
dr--;
}
dq[++dr] = i;
if(i >= k){
sol += a[dq[st]];
}
}
g << sol;
return 0;
}