#include #include #include #include #include #include #include #include #include static const int MOD = 1000000007; using ll = int64_t; using u32 = uint32_t; using namespace std; template constexpr T INF = ::numeric_limits::max()/32*15+208; vector get_prime(int n) { if(n <= 1) return vector{}; vector prime(static_cast(n + 1), true); vector res; prime[0] = false; prime[1] = false; for(int i = 2; i * i <= n; i++){ if(prime[i]) for(int j = i << 1; j <= n; j += i) prime[j] = false; } for (int i = 2; i <= n; ++i) { if(prime[i]) res.emplace_back(i); } return res; } template vector make_v(U size, const T& init){ return vector(static_cast(size), init); } template auto make_v(U size, Ts... rest) { return vector(static_cast(size), make_v(rest...)); } template void chmin(T &a, const T &b){ a = (a < b ? a : b); } template void chmax(T &a, const T &b){ a = (a > b ? a : b); } int main() { int n; cin >> n; if(n <= 1){ puts("-1"); return 0; } auto v = get_prime(n); auto dp = make_v(2, n+1, -1); dp[0][0] = 0; for (int i = 0; i < v.size(); ++i) { int now = i&1, nxt = now^1; dp[nxt] = dp[now]; for (int j = 0; j <= n; ++j) { if(j+v[i] > n) break; if(dp[now][j] == -1) continue; chmax(dp[nxt][j+v[i]], dp[now][j]+1); } } cout << dp[v.size()%2][n] << "\n"; return 0; }