Pagini recente » Cod sursa (job #1048688) | Cod sursa (job #2504732) | Cod sursa (job #2665796) | Cod sursa (job #1908528) | Cod sursa (job #2391775)
#include <fstream>
#define Nmax 100005
using namespace std;
ifstream fin ("rmq.in");
ofstream fout ("rmq.out");
int n, q, m[Nmax][30], a[Nmax], i, j, x, y, k, lg;
int main()
{
fin >> n >> q;
for(i=1; i<=n; i++)
fin >> a[i];
for(i=1; i<=n; i++)
m[i][0]=a[i];
for(j=1; (1<<j) <= n ; j++)
for(i=1; i+j-1 <=n ; i++)
m[i][j]=min(m[i][j-1], m[i+(1<<(j-1))][j-1]);
for(i=1; i<=q; i++)
{
fin >> x >> y;
k=0;
lg=y-x+1;
while((1<<k+1) <= lg)
k++;
fout << min (m[x][k], m[y-(1<<k)+1][k]) << '\n';
}
return 0;
}