Cod sursa(job #2986923)

Utilizator PingStrpewpewpac PingStr Data 1 martie 2023 17:04:51
Problema Range minimum query Scor 20
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.85 kb
#include <bits/stdc++.h>
using namespace std;

const int N = 100001;
const int L = 102;

/*const int N = 10;
const int L = 10; */


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

int n, k, m[N][L], logs[L], x, y;    // m[3][2] = min(m[3][2 ^ 1],m[3 + 2^1][2^1])
// 2 4 5 2 4 6 7 8 3

int qr(int l, int r)
{
    int len = r - l + 1;
    int lg = logs[len];
    return min(m[l][lg],m[r-(1<<lg) + 1][lg]);
}

int main()
{
    fin>>n>>k;
    for (int i = 2; i <= L; i++)
        logs[i] = logs[i/2] + 1; 
    for (int i = 1; i <= n; i++)
    {
        fin>>m[i][0];
    }
    for (int j = 1; j <= logs[n]; j++)
    {
        for (int i = 1; i + (1<<(j - 1))<= n; i ++)
        {
            m[i][j] = min(m[i][j - 1], m[i + (1<<(j - 1))][j - 1]);
        }
    }
    for (int i = 1; i <= k; i++)
    {
        fin>>x>>y;
        fout<<qr(x,y)<<"\n";
    }
    return 0;
}