#include int ri() { int n; scanf("%d", &n); return n; } int main() { int n = ri(); int a[n]; for (auto &i : a) i = ri(); int x = std::min(n, 22); static int used[22 * 150000 * 2 + 1]; for (auto &i : used) i = -1; for (int i = 1; i < 1 << x; i++) { int cur = 0; for (int j = 0; j < x; j++) if (i >> j & 1) cur += a[j]; if (used[cur + 22 * 150000] != -1) { puts("Yes"); for (int j = 0; j < n; j++) { if (j < x) printf("%d ", a[j] * ((i >> j & 1) - (used[cur + 22 * 150000] >> j & 1))); else printf("0 "); } puts(""); return 0; } used[cur + 22 * 150000] = i; } puts("No"); return 0; }