Cod sursa(job #3155112)

Utilizator andreea_condreaCondrea Andreea andreea_condrea Data 7 octombrie 2023 13:04:04
Problema Range minimum query Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.73 kb
#include <bits/stdc++.h>

using namespace std;

ifstream fin("rmq.in");
ofstream fout("rmq.out");

const int MAX=1e5+5, LOG=20+5;
int sp[MAX][LOG], v[MAX];
void rmq(int n){
    int i, j;
    for(i=0; i<n; i++)
        sp[i][0]=v[i];
    for(j=1; j<=log2(n); j++){
        for(i=0; (i+(1<<j))-1<n; i++){
            sp[i][j]=min(sp[i][j-1], sp[i+(1<<(j-1))][j-1]);
        }
    }
}
int query(int a, int b){
    int maxp;
    maxp=log2(b-a+1);
    return min(sp[a][maxp], sp[b+1-(1<<maxp)][maxp]);
}
int main()
{
    int n, q, i, a, b;
    fin>>n>>q;
    for(i=0; i<n; i++)
        fin>>v[i];
    rmq(n);
    for(i=0; i<q; i++){
        fin>>a>>b;
        fout<<query(a-1, b-1)<<'\n';
    }
    return 0;
}