Pagini recente » Cod sursa (job #786401) | Cod sursa (job #3293093) | Cod sursa (job #2656708) | Cod sursa (job #525584) | Cod sursa (job #2529243)
#include<fstream>
using namespace std;
int n,k,i,mi[500001],v[500001],ma,p,u,st,dr;
ifstream f("secventa.in");
ofstream g("secventa.out");
int main()
{
f >> n >> k;
ma = -30001;
for(i = 1;i <= n; ++i)
f >> v[i];
p = u = 1;
mi[p] = 1;
for(i = 2; i <= n; ++i)
{
while(p <= u && v[i] <= v[mi[u]])
u--;
u++;
mi[u] = i;
while(p <= u && i - mi[p] >= k)
p++;
if(v[mi[p]] > ma && i >= k)
{
ma = v[mi[p]];
dr = i;
}
}
g << dr - k + 1 << " " << dr << " " << ma;
return 0;
}