#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll = long long; using vi = vector; using vvi = vector; using vl = vector; using vvl = vector; using vb = vector; using vvb = vector; using vd = vector; using vs = vector; using pii = pair; using pll = pair; using pdd = pair; using vpii = vector; using vpll = vector; using vpdd = vector; const int inf = (1 << 30) - 1; const ll INF = 1LL << 60; const int MOD = 1000000007; //const int MOD = 998244353; int main() { int n; cin >> n; vi a(n); int sum = 0; for (int i = 0; i < n; i++) { cin >> a[i]; sum += a[i]; } if (sum % 2) { cout << "impossible" << endl; return 0; } sum /= 2; vb dp(sum + 1, false); dp[0] = true; for (int i = 1; i <= n; i++) { for (int j = sum - a[i - 1]; j >= 0; j--) { dp[j + a[i - 1]] = dp[j + a[i - 1]] | dp[j]; } } if (dp[sum]) cout << "possible" << endl; else cout << "impossible" << endl; return 0; }