#include using namespace std; /*{{{*/ //template #define rep(i,n) for(int i=0;i::max()/2; constexpr long long LINF = numeric_limits::max()/3; #define mp make_pair #define pb push_back #define eb emplace_back #define fi first #define se second #define all(v) (v).begin(),(v).end() #define sz(x) (int)(x).size() #define debug(x) cerr<<#x<<":"< ostream& operator<<(ostream& os,const vector& vec){ os << "["; for(const auto& v : vec){ os << v << ","; } os << "]"; return os; } template ostream& operator<<(ostream& os,const pair& p){ os << "(" << p.first << ","<< p.second <<")"; return os; } template ostream& operator<<(ostream& os,const set& st){ os<<"{"; for(T v:st) os< inline void chmax(T &x,U y){ if(y>x) x = y; } template inline void chmin(T &x,U y){ if(y pii; typedef vector vi; typedef vector vvi; ll gcd(ll a,ll b){ if(b==0) return a; else return gcd(b,a%b); } //constexpr double eps = 1e-14; constexpr double eps = 1e-10; constexpr ll mod = 1e9+7; const int dx[]={1,0,-1,0} ,dy[] = {0,1,0,-1}; /*}}}*/ constexpr ll max_n = 20000; bool prime[max_n+2]; int dp[max_n+2]; int main(){ int N; cin >> N; rep(i,max_n+2) prime[i] = true; prime[0] = prime[1] = false; for(int i=2;i<=max_n;i++){ if(!prime[i]) continue; for(int j=2;i*j<=max_n;j++) prime[i*j] = false; } rep(i,max_n+1) dp[i] = -1; dp[0] = 0; for(int i=0;i<=max_n;i++){ if(!prime[i])continue; for(int j=max_n;j>=0;j--){ if(dp[j] == -1) continue; if(i+j>max_n) continue; dp[i+j] = max(dp[i+j] , dp[j] + 1); } } //rep(i,20) cout << i << " " << dp[i] << endl; cout << dp[N] << endl; }