N, M = map(int, input().split()) LRXY = [list(map(int, input().split())) for _ in range(N)] A = list(map(int, input().split())) maxa = max(A) from collections import defaultdict dic = defaultdict(list) for i, (l, r, x, y) in enumerate(LRXY): if maxa < r: LRXY[1] = maxa r = maxa dic[(x, y)].append((l, r)) maxa = max(maxa, y) ans = [0] * (maxa + 1) for k, v in dic.items(): x, y = k n = maxa // x + 2 imost = [0] * (n + 1) for l, r in v: L = - ((y - l) // x) R = (r - y) // x imost[L] += 1 imost[R + 1] -= 1 for i in range(n - 1): tmp = imost[i] imost[i + 1] += tmp if i * x + y <= maxa: ans[i * x + y] += tmp for a in A: print(ans[a])