#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll=long long; template using V = vector; template using P = pair; using vll = V; using vvll = V; #define ALL(v) v.begin(),v.end() template < class T > inline bool chmax(T& a, T b) {if (a < b) { a=b; return true; } return false; } template < class T > inline bool chmin(T& a, T b) {if (a > b) { a=b; return true; } return false; } #define DEBUG_VLL(vec) REP(sz, vec.size()) std::cerr<> n; V a(n + 1); for (int i = 1; i <= n; i++) cin >> a[i]; ll acca = 0; for (int i = n; i > 0; i--) { if ((a[i] + acca) % i != 0) { cout << "No\n"; return 0; } else { acca += (a[i] + acca) / i; } } cout << "Yes\n"; return 0; }