Pagini recente » Cod sursa (job #2555572) | Cod sursa (job #1315476) | Cod sursa (job #1667691) | Cod sursa (job #2292399) | Cod sursa (job #1274610)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("secventa.in");
ofstream g("secventa.out");
const int NMax = 500010;
int v[NMax],deq[NMax];
int main()
{
int N,K,fata,spate,pz,bmn = -NMax,mn = -NMax;
f >> N >> K;
for(int i = 1; i <= N; i++)
f >> v[i];
fata = 1;
spate = 0;
for(int i = 1; i <= N; i++){
while(fata <= spate && v[i] <= v[deq[spate]])
spate--;
deq[++spate] = i;
if(deq[fata] == i-K)
fata++;
if(i >= K)
mn = v[deq[fata]];
if(mn > bmn){
bmn = mn;
pz = i;
}
}
g << pz - K << " " << pz << " " << bmn;
return 0;
}