Cod sursa(job #1241457)

Utilizator alexalghisiAlghisi Alessandro Paolo alexalghisi Data 13 octombrie 2014 16:21:57
Problema Range minimum query Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.8 kb
#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;
}