Pagini recente » Borderou de evaluare (job #1750698) | Cod sursa (job #540572) | Cod sursa (job #2662474) | Cod sursa (job #570987) | Cod sursa (job #1367962)
#include <cstdio>
using namespace std;
int n, k, i, p, u, v[5000010], a[5000010];
long long s;
int main(){
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
scanf("%d %d", &n, &k);
for(i=1; i<=n; i++)
scanf("%d", &v[i]);
p=1;
u=0;
for(i=1; i<k; i++)
{
while(v[ a[u] ]>v[i] && u>=p)
u--;
a[++u]=i;
}
for(i=k; i<=n; i++)
{
if(a[p]==i-k)
p++;
while(v[ a[u] ]>v[i] && u>=p)
u--;
a[++u]=i;
s=s+1LL*v[ a[p] ];
}
printf("%lld\n", s);
return 0;
}