#include using namespace std; #define INF 1000000000 #define REP(i,n) for(int (i)=0;(i)<(int)(n);(i)++) typedef long long ll; vectorv; int main(){ long long N; cin>>N; long long ans=N-1; for(ll i=1;i<10000001;i++){ if(i*i>=N)break; if(N%i==0)v.push_back(i); } v.push_back(N); for(ll i=1;v[i]*v[i]*v[i]<=N;i++){ if(N%v[i]!=0)continue; long long M=N/v[i]; for(int j=1;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<