Pagini recente » Cod sursa (job #2936555) | Cod sursa (job #2395013) | Cod sursa (job #2400923) | Cod sursa (job #2646882) | Cod sursa (job #2676404)
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("secventa.in");
ofstream fout("secventa.out");
const int NMAX = 500005;
int v[NMAX];
deque <int> dq;
int main()
{
int n,k,i,maxim = -300000,st,dr;
fin>>n>>k;
for(i = 1;i <= n;i++)
fin>>v[i];
for(i = 1;i < k;i++)
{
while(!dq.empty() && dq.front() > v[i])
dq.pop_front();
dq.push_front(i);
}
for(;i <= n;i++)
{
while(!dq.empty() && dq.back() < i - k + 1)
dq.pop_back();
while(!dq.empty() && v[dq.front()] > v[i])
dq.pop_front();
dq.push_front(i);
if(v[dq.back()] > maxim)
{
maxim = v[dq.back()];
st = i - k + 1;
dr = i;
}
}
fout<<st<<" "<<dr<<" "<<maxim;
return 0;
}