Pagini recente » Cod sursa (job #2281607) | Cod sursa (job #881136) | Cod sursa (job #2708152) | Cod sursa (job #2523811) | Cod sursa (job #998582)
Cod sursa(job #998582)
#include <cstdio>
#include <algorithm>
using namespace std;
int dp[20][100005];
int l2(int x){
int nr = 0;
while(x){
++nr;
x >>= 1;
}
return max(nr - 1, 0);
}
int main(){
freopen("rmq.in", "r", stdin);
freopen("rmq.out", "w", stdout);
int n, m;
scanf("%d%d", &n, &m);
for(int i = 1; i <= n; ++i)
scanf("%d", &dp[0][i]);
for(int i = 1; 1 << i <= n; ++i)
for(int j = 1; j <= n; ++j){
dp[i][j] = dp[i - 1][j];
if(j + (1 << (i - 1)) <= n)
dp[i][j] = min(dp[i][j], dp[i - 1][j + (1 << (i - 1))]);
}
for(int i = 1; i <= m; ++i){
int x, y;
scanf("%d%d", &x, &y);
int lp = l2(y - x);
printf("%d\n", min(dp[lp][x], dp[lp][y - (1 << lp) + 1]));
}
return 0;
}