def make_divisors(n): divisors = [] #必要に応じてsetにしても良いかも i = 1 while i ** 2 <= n: if n % i == 0: divisors.append(i) if i ** 2 != n: divisors.append(n//i) i += 1 divisors.sort() return divisors N = int(input()) D1 = make_divisors(N) ans = N for d1 in D1: tmp1 = d1 - 1 N2 = N // d1 D2 = make_divisors(N2) for d2 in D2: tmp2 = tmp1 + d2 - 1 tmp2 += N2 // d2 - 1 ans = min(ans,tmp2) print(ans, N - 1)