Pagini recente » Rating Ciobotariu Andrei (UltraTDK) | Cod sursa (job #1705898) | Cod sursa (job #1160211) | Cod sursa (job #1997312) | Cod sursa (job #1760912)
#include <iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int r[100001][16],log[100001];
int main()
{
FILE*fin,*fout;
int n,m,i,j,a,b,rez,l;
fin=fopen("rmq.in","r");
fscanf(fin,"%d%d",&n,&m);
log[1]=0;
for(i=2;i<=n;i++)
log[i]=1+log[i/2];
for(i=1;i<=n;i++){
fscanf(fin,"%d",&r[i][0]);
for(j=1;(1<<j)<=i;j++)
r[i][j]=min(r[i-(1<<(j-1))][j-1],r[i][j-1]);
}
fout=fopen("rmq.out","w");
for(i=1;i<=m;i++){
fscanf(fin,"%d%d",&a,&b);
l=log[b-a+1];
rez=min(r[a+(1<<l)-1][l],r[b][l]);
fprintf(fout,"%d\n",rez);
}
fclose(fout);
fclose(fin);
return 0;
}