Pagini recente » Cod sursa (job #2793983) | Cod sursa (job #102261) | Cod sursa (job #750776) | Cod sursa (job #1192592) | Cod sursa (job #1882001)
#include <bits/stdc++.h>
using namespace std;
const int kMaxN = 100000;
const int kMaxLogN = 17;
int n, m;
int v[kMaxLogN + 1][kMaxN + 1];
void rmq_build()
{
for (int i = 1; (1 << i) <= n; ++i) {
for (int j = 1; j <= n - (1 << i) + 1; ++j) {
v[i][j] = min(v[i - 1][j], v[i - 1][j + (1 << (i - 1))]);
}
}
}
int rmq_query(int a, int b)
{
int k = 1;
while (k <= a - b) k <<= 1;
k >>= 1;
return min(v[k][a], v[k][b - (1 << k) + 1]);
}
int main()
{
freopen("rmq.in", "rt", stdin);
freopen("rmq.out", "wt", stdout);
int a, b;
scanf("%d %d", &n, &m);
for (int i = 1; i <= n; ++i) {
scanf("%d", &v[0][i]);
}
rmq_build();
for (int i = 0; i < m; ++i) {
scanf("%d %d", &a, &b);
printf("%d\n", rmq_query(a, b));
}
return 0;
}