Pagini recente » Cod sursa (job #2320631) | Cod sursa (job #2237095) | Cod sursa (job #1479849) | Cod sursa (job #1240742) | Cod sursa (job #1557183)
#include <fstream>
#include <deque>
using namespace std;
const int MAX = 500000;
int N, K, V[MAX];
deque<int> deque;
int main() {
ifstream f("secventa.in");
ofstream g("secventa.out");
f >> N >> K;
int min = -30001;
int end = 0;
for(int i = 1; i <= N ; i++) {
f >> V[i];
while(!(deque.empty()) && V[deque.back()] >= V[i]) {
deque.pop_back();
}
deque.push_back(i);
if(deque.front() <= i-K) {
deque.pop_front();
}
if(i >= K && min < V[deque.front()]) {
min = V[deque.front()];
end = i;
}
}
g<<end-K+1<<" "<<end<<" "<<min;
return 0;
}