Pagini recente » Cod sursa (job #390970) | Cod sursa (job #2431229) | Cod sursa (job #3038831) | Cod sursa (job #2460931) | Cod sursa (job #363934)
Cod sursa(job #363934)
#include<cstdio>
using namespace std;
int n,k,a[500001],deque[500001],front,back,sol=-30001,init,bestk;
char sir[500001];
int main()
{
freopen("secventa.in","r",stdin);
freopen("secventa.out","w",stdout);
scanf("%d %d ",&n,&k);
int ind, x;
fgets(sir, 500001, stdin), x = ind = 0;
front=1;back=0;
{front=1;back=0;
for(int j=1;j<=n;j++)
{ a[j]=0;int semn=0;
if(sir[ind]=='-') {semn=1;ind++;}
for(; sir[ind] >= '0' && sir[ind] <= '9'; ind++)
a[j] = a[j]*10+(sir[ind]-'0');
if(semn==1) a[j]*=(-1);
ind++;
while(front<=back && a[j]<a[deque[back]]) back--;
deque[++back]=j;
if(deque[front]==j-k) front++;
if(j>=k)if(sol<a[deque[front]]) {sol=a[deque[front]];init=j-k+1;bestk=k;}
}
}
printf("%d %d %d",init,init+bestk-1,sol);
return 0;}