Pagini recente » Cod sursa (job #1202266) | Cod sursa (job #1976082) | Diferente pentru problema/turnuri4 intre reviziile 6 si 5 | Diferente pentru problema/afaceri intre reviziile 7 si 5 | Cod sursa (job #2841991)
#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=log2(r-l+1);
out<<min(spars_table[l][k],spars_table[r-(1<<k)+1][k])<<'\n';
}
return 0;
}