Cod sursa(job #3232152)

Utilizator ClassicalClassical Classical Data 29 mai 2024 09:58:03
Problema Range minimum query Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.68 kb
#include <bits/stdc++.h>

using namespace std;

const int N = (int) 1e5 + 7;
const int K = 16;
int rmq[K][N], n, q, lg[N];

int main() {
#ifdef INFOARENA
	freopen ("rmq.in", "r", stdin);
	freopen ("rmq.out", "w", stdout);
#endif

	cin >> n >> q;
	for (int i = 1; i <= n; i++) {
		cin >> rmq[0][i];
	}
	for (int k = 1; (1 << k) <= n; k++) {
		for (int i = 1; i + (1 << k) - 1 <= n; i++) {
			rmq[k][i] = min(rmq[k - 1][i], rmq[k - 1][i + (1 << (k - 1))]);
		}
	}
	for (int i = 2; i <= n; i++) {
		lg[i] = 1 + lg[i / 2];
	}
	while (q--) {
		int l, r, k;
		cin >> l >> r;
		k = lg[r - l + 1];
		cout << min(rmq[k][l], rmq[k][r - (1 << k) + 1]) << "\n";
	}
	return 0;
}