n = int(input()) a = list(map(int,input().split())) M = 10 ** 9 + 7 p = [1, 1, 0, -3, -9, -18] q = [-1, -2, -3, -3, 0, 9] r = [0, 1, 3, 6, 9, 9] def g(n, l): if n >= 6: return pow(M - 27, n // 6, M) * g(n % 6, l) % M return l[n] if l[n] >= 0 else M + l[n] ll = [g(n - 2, l) for l in (p, q, r)] res = [] for k in range(3): cnt = 0 for j, i in enumerate(ll): cnt += i * a[(j + k) % 3] cnt %= M res.append(cnt) print(*res)