#include using namespace std; #define INF 1000000000 #define REP(i,n) for(int (i)=0;(i)<(int)(n);(i)++) typedef long long ll; vector v; int main(){ long long N; cin>>N; for(ll i=1;i*i<=N;i++){ if(N%i==0){ v.push_back(i); } } v.push_back(10000001); long long ans=N-1; for(int i=0;v[i]<=100000&&v[i]*v[i]*v[i]<=N;i++){ if(N%v[i]!=0)continue; long long M=N/v[i]; for(long long j=i;v[j]<=10000000&&v[i]*v[j]*v[j]<=N;j++){ if(M%v[j]!=0)continue; long long L=M/v[j]; ans=min(L+v[i]+v[j]-3,ans); } } cout<