// yukicoder: No.634 硬貨の枚数1 // 2019.5.1 bal4u #include #include #define KMAX 4471 // 4471*4472/2 = 9997156 int t[KMAX+5], sz; int check(int x) { int b; x <<= 3, x++; b = (int)sqrt((double)x); return b*b == x; } int main() { int a, k, N; scanf("%d", &N); sz = 0, k = 0, a = 0; while (1) { a += ++k; if (a == N) { puts("1"); return 0; } if (a > N) break; t[sz++] = a; } a = N >> 1; for (k = 0; t[k] <= a; k++) { if (check(N-t[k])) { puts("2"); return 0; } } puts("3"); return 0; }