Pagini recente » Cod sursa (job #2639931) | Cod sursa (job #3185851) | Diferente pentru utilizator/brainwashed20 intre reviziile 35 si 36 | Cod sursa (job #2121521) | Cod sursa (job #342505)
Cod sursa(job #342505)
#include<cstdio>
using namespace std;
int n,k,a[500001],deque[500001],front,back,sol=-30001,init,bestk;
int main()
{freopen("secventa.in","r",stdin);
freopen("secventa.out","w",stdout);
scanf("%d %d ",&n,&k);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
front=1;back=0;
for(int i=k;i<=n;i++)
{front=1;back=0;
for(int j=1;j<=n;j++)
{while(front<=back && a[j]<a[deque[back]]) back--;
deque[++back]=j;
if(deque[front]==j-i) front++;
if(j>=i)if(sol<a[deque[front]]) {sol=a[deque[front]];init=deque[front];bestk=i;}
}
}
printf("%d %d %d",init,init+bestk-1,sol);
return 0;}