Cod sursa(job #1969325)

Utilizator caprariuapCaprariu Alin-Paul caprariuap Data 18 aprilie 2017 13:34:26
Problema Range minimum query Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.01 kb
#include <fstream>
#include <cstring>
#include <vector>
#include <algorithm>
#include <stack>
#include <iomanip>
#include <queue>
using namespace std;

ifstream fin("rmq.in");
ofstream fout("rmq.out");
#define nmax 100010
int doi[20],rmq[nmax][20],n,m,i,j,logb2[nmax],a[nmax];

int main()
{
    fin >> n >> m;
    doi[0]=1;
    for (i=1; i<20; i++)
        doi[i]=doi[i-1]*2;
    for (i=2; i<=n; i++)
        logb2[i]=logb2[i/2]+1;
    for (i=1; i<=n; i++)
    {
        fin >> a[i];
        rmq[i][0]=a[i];
    }
    int k=logb2[n];
    for (i=1; i<=k; i++)
    {
        for (j=1; j<=n-doi[i]+1; j++)
            rmq[j][i]=min(rmq[j][i-1],rmq[j+doi[i-1]][i-1]);
    }
    for (i=1; i<=m; i++)
    {
        int x,y;
        fin >> x >> y;
        int d=logb2[y-x+1];
        fout << min(rmq[x][d],rmq[min(max(y-doi[d]+1,1),n)][d]) << '\n';
    }
//    for (i=0; i<=k; i++)
//    {
//        for (j=1; j<=n; j++)
//            fout << rmq[j][i] << ' ';
//        fout << '\n';
//    }
}