Pagini recente » Cod sursa (job #1405591) | Cod sursa (job #2449359) | Cod sursa (job #2939066) | Cod sursa (job #1194509) | Cod sursa (job #3226831)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("secventa.in");
ofstream fout ("secventa.out");
int v[500005];
deque <pair<int,int>> d;
int main()
{
int n,x,Max = -999999999,m,dr = 0,h;
fin >> n >> m;
for (int i=1;i<=n;++i){
fin >> v[i];
}
for (int k=m;k<=n;++k){
d.empty();
for (int i=1;i<=n;++i){
x = v[i];
while (!d.empty() and i-d.front().second>=k) d.pop_front();
while (!d.empty() and d.back().first>=x) d.pop_back();
d.push_back({x,i});
if (i>=k){
if (Max<=d.front().first){
Max = d.front().first;
dr = i;
h = k;
}
}
}
}
fout << dr-h+1 << ' ' << dr << ' ' << Max;
return 0;
}