Cod sursa(job #1899965)

Utilizator RazvanR104Razvan-Andrei Ciocoiu RazvanR104 Data 3 martie 2017 03:05:39
Problema Pq Scor 100
Compilator cpp Status done
Runda Arhiva ICPC Marime 1.58 kb
#include <bits/stdc++.h>

using namespace std;

const int NMAX = 100010;

int N, Q;
int V[NMAX], ST[4 * NMAX];
int lastSeen[NMAX];
int answer[NMAX];
vector<pair<int, int>> queryList[NMAX];

void updateTree(int node, int left, int right, int pos, int value) {
	if (left == right) {
		ST[node] = value;
		return;
	}
	int mid = (left + right) / 2;
	if (pos <= mid)
		updateTree(node * 2, left, mid, pos, value);
	else
		updateTree(node * 2 + 1, mid + 1, right, pos, value);
	ST[node] = max(ST[node * 2], ST[node * 2 + 1]);
}

int queryTree(int node, int left, int right, int qleft, int qright) {
	if (left >= qleft && right <= qright)
		return ST[node];
	int mid = (left + right) / 2;
	int answer = -1;
	if (qleft <= mid)
		answer = max(answer, queryTree(node * 2, left, mid, qleft, qright));
	if (qright > mid)
		answer = max(answer, queryTree(node * 2 + 1, mid + 1, right, qleft, qright));
	return answer;
}

int main() {
	assert(freopen("pq.in", "r", stdin));
	assert(freopen("pq.out", "w", stdout));
	int i;
	memset(ST, -1, sizeof ST);
	memset(lastSeen, -1, sizeof lastSeen);
	scanf("%d %d", &N, &Q);
	for (i = 1; i <= N; ++i)
		scanf("%d", &V[i]);
	for (i = 1; i <= Q; ++i) {
		int x, y;
		scanf("%d %d", &x, &y);
		queryList[y].push_back({x, i});
	}
	for (i = 1; i <= N; ++i) {
		if (lastSeen[V[i]] != -1)
			updateTree(1, 1, N, lastSeen[V[i]], i - lastSeen[V[i]]);
		lastSeen[V[i]] = i;
		for (const auto &it: queryList[i])
			answer[it.second] = queryTree(1, 1, N, it.first, i);
	}
	for (i = 1; i <= Q; ++i)
		cout << answer[i] << '\n';
	return 0;
}