Pagini recente » Cod sursa (job #229268) | Cod sursa (job #651587) | Cod sursa (job #1576329) | Cod sursa (job #2812667) | Cod sursa (job #2841908)
#include <bits/stdc++.h>
using namespace std;
ifstream in("rmq.in");
ofstream out("rmq.out");
int spars_table[100001][20];
int main()
{
int n,m,i,j,k,l,r;
in>>n>>m;
for(i=1;i<=n;++i){
in>>spars_table[i][0];
}
for(j=1;(1<<j)<=n;++j)
for(i=1;i<=n-(1<<j)+1;++i)
{
spars_table[i][j]=min(spars_table[i][j-1],spars_table[i+(1<<(j-1))][j-1]);
}
for(i=1;i<=m;++i)
{
in>>l>>r;
k=int(log(r-l+1));
out<<min(spars_table[l][k],spars_table[r-(1<<k)+1][k])<<'\n';
}
return 0;
}