Pagini recente » Cod sursa (job #553832) | Cod sursa (job #211306) | Sandbox (cutiuţa cu năsip) | Cod sursa (job #2218613) | Cod sursa (job #813303)
Cod sursa(job #813303)
//secventa
#include <fstream>
using namespace std;
int n, k, v[5000001], dq[5000001], p=1, u=0;
int main()
{ int max,pos;
ifstream f("secventa.in");
ofstream g("secventa.out");
int i;
f>>n>>k;
max=-1<<31;
pos=0;
for(i=1;i<=n;++i)
f>>v[i];
for(i=1;i<=n;++i)
{
while(p<=u && v[i]<=v[dq[u]])
--u;
dq[++u]=i;
if(dq[p]==i-k)
++p;
if ((i>=k)&&(max<v[dq[p]])) {max=v[dq[p]];
pos=i; }
}
g<<pos-k+1<<" "<<pos<<" "<<max;
f.close();
g.close();
return 0;
}