Pagini recente » Cod sursa (job #1461308) | Cod sursa (job #2949272) | Cod sursa (job #2695434) | Cod sursa (job #2156237) | Cod sursa (job #3004217)
#include <bits/stdc++.h>
using namespace std;
ifstream in("rmq.in");
ofstream out("rmq.out");
int n, q;
const int N = 1e5 + 5;
int rmq[20][N], lg[N];
int main()
{
in >> n >> q;
for(int i = 1; i <= n; i++)
{
in >> rmq[0][i];
if(i == 1)
continue;
lg[i] = lg[i / 2] + 1;
}
for(int e = 1; e <= lg[n] ; e++)
{
for(int i = (1 << e); i <= n; i++)
{
int p = (1 << (e - 1));
rmq[e][i] = min(rmq[e - 1][i], rmq[e - 1][i - (1 << (e - 1))]);
}
}
while(q--)
{
int st, dr;
in >> st >> dr;
int e = lg[dr - st + 1];
out << min(rmq[e][st + (1 << e) - 1], rmq[e][dr]) << '\n';
}
return 0;
}