Pagini recente » Cod sursa (job #2370673) | Cod sursa (job #2152326) | Argumentatia | Cod sursa (job #525930) | Cod sursa (job #3155113)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rmq.in");
ofstream fout("rmq.out");
const int MAX=1e5+5, LOG=20+5;
int sp[MAX][LOG], v[MAX];
void rmq(int n){
int i, j;
for(i=0; i<n; i++)
sp[i][0]=v[i];
for(j=1; j<=log2(n); j++){
for(i=0; (i+(1<<j))-1<n; i++){
sp[i][j]=min(sp[i][j-1], sp[i+(1<<(j-1))][j-1]);
}
}
}
int query(int a, int b){
int maxp;
maxp=log2(b-a+1);
return min(sp[a][maxp], sp[b+1-(1<<maxp)][maxp]);
}
int main()
{
int n, q, i, a, b;
fin>>n>>q;
for(i=0; i<n; i++)
fin>>v[i];
rmq(n);
for(i=0; i<q; i++){
fin>>a>>b;
fout<<query(a-1, b-1)<<'\n';
}
return 0;
}