#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); int N; cin >> N; vector isT(N + 1, 0); for(int i = 1; i * (i + 1) / 2 <= N; i++) isT[i * (i + 1) / 2] = 1; if(isT[N]) { cout << 1 << endl; } else { for(int i = 1; i <= N; i++) if(isT[i] && isT[N - i]) { cout << 2 << endl; return 0; } cout << 3 << endl; } }