#include<bits/stdc++.h>
using namespace std;
int n,js,b[26];
double mn=2e9,x[26],y[26],g[26][26];
void dfs(double s,int x,int y){
if(js==92707138){
printf("%.2lf",mn);
exit(0);
}
if(s>=mn) return;
if(y==n){
mn=min(mn,s);
return;
}
for(int i=1;i<=n;i++)
if(b[i]==0){
js++;
b[i]=1;
dfs(s+g[x][i],i,y+1);
b[i]=0;
}
}
int main()
{
int i,j;
cin>>n;
for(i=1;i<=n;i++) cin>>x[i]>>y[i];
for(i=0;i<=n;i++)
for(j=i+1;j<=n;j++)
g[i][j]=g[j][i]=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
b[0]=1;
dfs(0,0,0);
printf("%.2lf",mn);
return 0;
}