Pagini recente » Cod sursa (job #1378688) | Cod sursa (job #2253809) | Cod sursa (job #404494) | Cod sursa (job #1539439) | Cod sursa (job #624278)
Cod sursa(job #624278)
#include <fstream>
#include <stdio.h>
#include <limits.h>
using namespace std;
ifstream f("secventa.in");
FILE *g=fopen("secventa.out","w");
int n,k,v[500001],deq[500001],maxb=INT_MIN,pi,pf;
int main(void){
register int i,j;
// fscanf(f,"%d %d",&n,&k);
f>>n>>k;
deq[1]=1;
//fscanf(f,"%d",&v[1]);
f>>v[1];
long long sum=0;
int p=1,u=1;
for(i=2;i<=n;i++){
//fscanf(f,"%d",&v[i]);
f>>v[i];
while(p<=u && v[deq[u]]>=v[i])
u--;
deq[++u]=i;
if(i-deq[p]==k)
p++;
if(i>=k){
if(v[deq[p]]>maxb){
maxb=v[deq[p]];
pf=deq[u];
}
}
}
fprintf(g,"%d %d %d",pf-k+1,pf,maxb);
return 0;
}