Pagini recente » Cod sursa (job #2733431) | Cod sursa (job #896495) | Cod sursa (job #385997) | Cod sursa (job #1045447) | Cod sursa (job #850643)
Cod sursa(job #850643)
#include <stdio.h>
#include <stdlib.h>
FILE*f;
FILE*g;
#define maxn 5000001
int A[ maxn ],deq[ maxn ], poz[ maxn ],B[maxn];
long long s;
int n,k,i,st,dr;
int main()
{
f=fopen("secventa.in","r");
g=fopen("secventa.out","w");
fscanf(f,"%d%d",&n,&k);s=0;
for (i=1;i<=n;i++)
fscanf(f,"%d",&A[i]);
st=1;dr=0;
for (i=1;i<=n;i++)
{ while ((A[i]<=deq[dr]) && (st<=dr))
dr--;
deq[++dr]=A[i];B[dr]=i;
poz[dr] = i;
if (poz[st]==i-k) st++;
}
fprintf (g,"%d %d %d",B[st],B[dr],deq[st]);
return 0;
}