import bisect N, A = map(int, input().split()) X = sorted(list(map(int, input().split()))) T = int(input()) LR = [list(map(int, input().split())) for _ in range(T)] last_heard = {i: -1 for i in range(N)} # bisect_leftとbisect_right関数を一度だけ呼び出す bisect_left = bisect.bisect_left bisect_right = bisect.bisect_right for t in range(T): L, R = LR[t] start = bisect_left(X, L) end = bisect_right(X, R) indices = set(range(start, end)) for i in indices: last_heard[i] = t+1 for i in range(N): print(last_heard[i])