#include using namespace std; int main() { int64_t n; cin >> n; if (n <= 2) { cout << n + 1 << endl; return 0; } for (int64_t p = 2; p * p <= n; p++) { int64_t s = 1; while (s * p + 1 <= n) { s = s * p + 1; } if (n % s == 0) { cout << p << endl; return 0; } } int64_t ans = n - 1; for (int64_t d = 1; (d + 1) * (d + 1) <= n; d++) { if (n % d == 0) { ans = n / d - 1; } } cout << ans << endl; }