Cod sursa(job #540953)

Utilizator Rares95Rares Arnautu Rares95 Data 24 februarie 2011 17:57:50
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
# include <stdio.h>
	  int n, k, i, first = 1, last, a[5000001], deque[5000001];
		long long s;
		int main ()
		{ freopen ("deque.in", "rt", stdin); freopen ("deque.out", "wt", stdout);
		  for (scanf ("%d%d", &n, &k), i = 1; i <= n; ++i) scanf ("%d", &a[i]);
			for (i = 1; i <= n; ++i)
			  { while (first <= last && a[i] <= a [deque [last]]) --last;
			    deque [++last] = i;
				  if (deque [first] == i - k) ++first;
					if (i >= k) s += a [deque [first]];
			  }
			printf ("%lld\n", s); return 0;
		}