Cod sursa(job #1910636)

Utilizator VladG26Ene Vlad-Mihai VladG26 Data 7 martie 2017 17:44:34
Problema Range minimum query Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <iostream>
#include <cmath>
#include <cstdio>
using namespace std;
int m,n,mCit[100002][18];
void citire()
{
    scanf("%d%d",&m,&n);
    for(int i=1;i<=m;i++)
    {
        scanf("%d",&mCit[i][0]);
    }
    for(int i=1;i<=log2(m);i++)
    {
        for(int j=1;j<=m;j++)
        {
            mCit[j][i]=min(mCit[j][i-1],mCit[j+1<<(i-1)][i-1]);
        }
    }
    int st,dr,aux;
    for(int i=1;i<=n;i++)
    {
        scanf("%d%d",&st,&dr);
        aux=(int)(log2(st-dr+1));
        printf("%d\n",min(mCit[st][aux],mCit[dr-aux][aux]));
    }

}
int main()
{
    freopen("rmq.in","r",stdin);
    freopen("rmq.out","w",stdout);
    citire();
    return 0;
}