Cod sursa(job #2397654)

Utilizator alexalghisiAlghisi Alessandro Paolo alexalghisi Data 4 aprilie 2019 17:41:47
Problema Range minimum query Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.7 kb
#include <iostream>
#include <fstream>
 
#define DN 100005
using namespace std;
 
ifstream f("rmq.in");
ofstream g("rmq.out");
 
int rmq[DN][22];
int n,m;
 
 
void read(){
 
    f>>n>>m;
    for(int i=1;i<=n;++i)
        f>>rmq[i][0];
 
}
int find_min(int &a,int &b){
 
    int p = 0;
    for(; a + (1<<p) <=b ;++p); --p;
    p = max(p,0);
    return min(rmq[a][p],rmq[b - (1<<p) + 1][p]);
}
 
 
void solve(){
 
    for(int p=1;p<=18;++p)
        for(int i=1;i+(1<<(p-1))<=n;++i)
            rmq[i][p] = min(rmq[ i ][ p - 1 ], rmq[i + (1<<(p-1)) ][ p - 1 ] );
 
    for(;m--;){
 
        int a,b;
        f>>a>>b;
        g<<find_min(a,b)<<"\n";
    }
}
 
int main()
{
    read();
    solve();
 
    return 0;
}