Ana şi Bogdan au participat la un concurs şi au obţinut premiul I, respectiv premiul al II-lea. La concurs există n
premii, numerotate de la 1
la n
, în ordinea în care sunt aşezate pe masă. Regulamentul concursului prevede că fiecare câştigător trebuie să aleagă exact k
premii aşezate pe poziţii consecutive. Fiindcă Ana are premiul I, ea poate să îşi aleagă prima premiile. Apoi Bogdan va alege şi el k
premii aşezate pe poziţii consecutive dintre cele rămase după ce a ales Ana. Ana este foarte supărată pe Bogdan, aşa că ea urmăreşte ca Bogdan să câştige cât mai puţin, fără să o intereseze prea mult ce premii alege ea.
Cerința
Scrieţi un program care, cunoscând n
, k
şi valorile celor n
premii, determină cel mai mic număr valmin
, astfel încât Bogdan să nu poate selecta k
premii aşezate pe poziţii consecutive cu o valoare totală mai mare decât valmin
.
Date de intrare
Fișierul de intrare castig.in
conţine pe prima linie două numere naturale n k
, reprezentând numărul total de premii şi respectiv numărul de premii consecutive pe care câştigătorii trebuie să le aleagă. Pe a doua linie se află n
numere naturale v[1]
, v[2]
, …, v[n]
reprezentând, în ordinea aşezării pe masă, valorile celor n
premii.
Date de ieșire
Fișierul de ieșire castig.out
va conţine o singură linie pe care va fi scris numărul natural valmin
, determinat conform cerinţei.
Restricții și precizări
3 ≤ n ≤ 100 000
1 ≤ k ≤ n/3
1 ≤ v[i] ≤ 1 000 000 000
, pentru1 ≤ i ≤ n
Exemplu:
castig.in
10 3 2 5 7 3 1 22 7 2 9 1
castig.out
15
Explicație
Dacă Ana alege premiile cu valorile 1 22 7
, secvenţa cea mai convenabilă pentru Bogdan este 5 7 3
(deci valmin
este 15
). Există şi alte alegeri bune pentru Ana (22 7 2
), dar valmin
rămâne acelaşi.