Pagini recente » Cod sursa (job #3282824) | Cod sursa (job #376574) | Cod sursa (job #516482) | Cod sursa (job #2047252) | Cod sursa (job #542064)
Cod sursa(job #542064)
# 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;
}