Cod sursa(job #542064)

Utilizator Rares95Rares Arnautu Rares95 Data 25 februarie 2011 19:13:44
Problema Secventa Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.63 kb
# include <stdio.h>
  using namespace std;
		int k, n, i, front = 1, back, deque[500001], a[500001], baza = -30001, vi = -1, vf = -1;
		int main ()
		{ freopen ("secventa.in", "r", stdin); freopen ("secventa.out", "w", stdout);
		  scanf ("%d%d", &n, &k);
			for (i = 1; i <= n; ++i) scanf ("%d", &a[i]);
			for (i = 1; i <= n; ++i)
			{ while (front <= back && a[i] <= a [ deque [ back ]]) back --;
			  deque [ ++ back ] = i;
			  if (deque [ front ] == i - k) front ++;
				if (i >= k && a [ deque [ front ]] > baza) {baza = a [ deque [ front ]]; vi = (vf = i) - k + 1;}
			}
		  printf ("%d %d %d\n", vi, vf, baza); return 0;
		}