import math
def find(u, par):
if par[u] != u:
par[u] = find(par[u], par)
return par[u]
def union(u, v, par, size):
u_root = find(u, par)
v_root = find(v, par)
if u_root == v_root:
return
if size[u_root] < size[v_root]:
par[u_root] = v_root
size[v_root] += size[u_root]
else:
par[v_root] = u_root
size[u_root] += size[v_root]
def ip():
return map(int,input().split())
T=1
T=int(input())
for __ in range(T):
n=int(input())
lst=list(ip())
if n%2==0:
b=[]
for i in range(0,n,2):
b.append(-lst[i+1])
b.append(lst[i])
print(*b)
continue
b=[0,0,0]
b[0]=-lst[2]
b[1]=-lst[2]
b[2]=lst[0]+lst[1]
for i in range(3,n,2):
b.append(-lst[i+1])
b.append(lst[i])
print(*b)
aW1wb3J0IG1hdGgKZGVmIGZpbmQodSwgcGFyKToKCiAgICBpZiBwYXJbdV0gIT0gdToKICAgICAgICBwYXJbdV0gPSBmaW5kKHBhclt1XSwgcGFyKQogICAgcmV0dXJuIHBhclt1XQoKZGVmIHVuaW9uKHUsIHYsIHBhciwgc2l6ZSk6CiAgICB1X3Jvb3QgPSBmaW5kKHUsIHBhcikKICAgIHZfcm9vdCA9IGZpbmQodiwgcGFyKQoKICAgIGlmIHVfcm9vdCA9PSB2X3Jvb3Q6CiAgICAgICAgcmV0dXJuIAoKCiAgICBpZiBzaXplW3Vfcm9vdF0gPCBzaXplW3Zfcm9vdF06CiAgICAgICAgcGFyW3Vfcm9vdF0gPSB2X3Jvb3QKICAgICAgICBzaXplW3Zfcm9vdF0gKz0gc2l6ZVt1X3Jvb3RdCiAgICBlbHNlOgogICAgICAgIHBhclt2X3Jvb3RdID0gdV9yb290CiAgICAgICAgc2l6ZVt1X3Jvb3RdICs9IHNpemVbdl9yb290XQoKZGVmIGlwKCk6CiAgICByZXR1cm4gbWFwKGludCxpbnB1dCgpLnNwbGl0KCkpCgoKCgpUPTEKVD1pbnQoaW5wdXQoKSkKZm9yIF9fIGluIHJhbmdlKFQpOgogICAgbj1pbnQoaW5wdXQoKSkKICAgIGxzdD1saXN0KGlwKCkpCgogICAgaWYgbiUyPT0wOgogICAgICAgIGI9W10KICAgICAgICBmb3IgaSBpbiByYW5nZSgwLG4sMik6CiAgICAgICAgICAgIGIuYXBwZW5kKC1sc3RbaSsxXSkKICAgICAgICAgICAgYi5hcHBlbmQobHN0W2ldKQogICAgICAgIHByaW50KCpiKQogICAgICAgIGNvbnRpbnVlCiAgICBiPVswLDAsMF0KICAgIGJbMF09LWxzdFsyXQogICAgYlsxXT0tbHN0WzJdCiAgICBiWzJdPWxzdFswXStsc3RbMV0KCiAgICBmb3IgaSBpbiByYW5nZSgzLG4sMik6CiAgICAgICAgYi5hcHBlbmQoLWxzdFtpKzFdKQogICAgICAgIGIuYXBwZW5kKGxzdFtpXSkKICAgIAogICAgcHJpbnQoKmIp