Pagini recente » Cod sursa (job #318232) | Cod sursa (job #2669476) | Cod sursa (job #992213) | Cod sursa (job #182338) | Cod sursa (job #3144554)
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int batog[320],v[100000];
int main()
{
FILE *fin, *fout;
int intrebare,min,rad,n,m,i,x,y;
fin=fopen("rmq.in", "r");
fscanf(fin, "%d%d", &n, &m);
rad=sqrt(n);
min=1000000;
for(i=0; i<n; i++){
fscanf(fin, "%d", &v[i]);
if(v[i]<min)
min=v[i];
if((i+1)%rad==0){
batog[i/rad]=min;
min=1000000;
}
}
fout=fopen("rmq.out", "w");
for(intrebare=0; intrebare<m; intrebare++){
fscanf(fin, "%d%d", &x, &y);
x--;
y--;
i=x;
min=1000000;
while(i<=y){
if(i%rad==0&&i+rad<=y){
if(batog[i/rad]<min)
min=batog[i/rad];
i+=rad;
}
else{
if(v[i]<min)
min=v[i];
i++;
}
}
fprintf(fout, "%d\n", min);
}
fclose(fin);
fclose(fout);
return 0;
}