Cod sursa(job #2046389)

Utilizator flaviu_2001Craciun Ioan-Flaviu flaviu_2001 Data 23 octombrie 2017 19:19:27
Problema Range minimum query Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.71 kb
#include <bits/stdc++.h>

using namespace std;

int lg2[100005], n, pd[20][100005], v[100005], test;

int main()
{
    ifstream fin ("rmq.in");
    ofstream fout ("rmq.out");
    lg2[2] = 1;
    for (int i = 3; i <= 100000; ++i)
        lg2[i] = lg2[i/2]+1;
    fin >> n >> test;
    for (int i = 1; i <= n; ++i)
        fin >> v[i];
    for (int i = 1; i < n; ++i)
        pd[0][i] = min(v[i], v[i+1]);
    for (int t = 1; t <= lg2[n-1]; ++t)
        for (int i = 1; i <= n-(1<<t); ++i)
            pd[t][i] = min(pd[t-1][i], pd[t-1][i+(1<<(t-1))]);
    while(test--){
        int x, y, sz;
        fin >> x >> y;
        fout << min(pd[sz][x], pd[sz][y-(1<<sz)]) << "\n";
    }
    fin.close();
    fout.close();
    return 0;
}