#include #define rep(i,n) for(int i = 0; i < (n); i++) using namespace std; typedef long long ll; int main(){ cin.tie(0); ios::sync_with_stdio(0); ll N,X,Y; cin >> N >> X >> Y; vector R(N); rep(i,N) cin >> R[i]; ll XY = X * X + Y * Y; if(N == 1 && XY != R[0] * R[0]) { cout << -1 << endl; } else { ll ma = accumulate(R.begin(), R.end(), 0LL) * 2 - *min_element(R.begin(), R.end()); ll mi = max(0LL, *min_element(R.begin(), R.end()) - (accumulate(R.begin(), R.end(), 0LL) - *min_element(R.begin(), R.end())) * 2); cout << (mi <= XY && XY <= ma ? "Yes" : "No") << endl; } }