Pagini recente » Cod sursa (job #299590) | Cod sursa (job #2580034) | Cod sursa (job #1910319) | Cod sursa (job #638998) | Cod sursa (job #1241457)
#include <iostream>
#include <fstream>
#define DN 100005
using namespace std;
ifstream f("rmq.in");
ofstream g("rmq.out");
int rmq[DN][25],n,m;
int find(int &a,int &b){
int p = 0;
for(; a + (1<<p) <= b ; ++p); --p;
/// (2,4)
cout << b-(1<<p)<<endl;
return min(rmq[a][p] , rmq[b-(1<<p)][p]);
}
void solve(){
for(;m--;){
int a,b;
f>>a>>b;
g<<find(a,b)<<"\n";
}
}
void build(){ /// Build rmq
for(int p = 1 ; p <= 18 ; ++p)
for(int i = 1; i + (1<<p) <=n ; ++i)
rmq[i][p] = min( rmq[i][p-1] , rmq[ i + (1<<(p-1)) + 1 ][p-1] ); /// Min ( i ... i + (1<<(p-1)) , i + (1<<(p-1)) + 1... n )
}
void read(){
f>>n>>m;
for(int i=1;i<=n;++i)
f>>rmq[i][0];
}
int main()
{
read();
build();
solve();
return 0;
}