from sys import setrecursionlimit setrecursionlimit(10**6) from collections import defaultdict def dfs(pos): if Dic[pos]: return Dic[pos] Flg[pos] = True ret = pos for nxt in G[pos]: if Flg[nxt]: continue ret = max(ret, dfs(nxt)) Flg[pos] = False Dic[pos] = ret return ret N = int(input()) X = list(map(int,input().split())) A = list(map(int,input().split())) G = defaultdict(list) for i in range(N): if X[i] - A[i] >= 0: G[X[i]].append(X[i] - A[i]) G[X[i]].append(X[i] + A[i]) Flg = defaultdict(int) Dic = defaultdict(int) for i in range(N): print(dfs(X[i]) - X[i])