c++SPFAsu
using namespace std;
int a[1005][3],f[1005][3],n,m,s,e;
double w[1005],d[1005];
int main(){
cin>>n;
for(int i=1;i<=n;i++)cin>>a[i][0]>>a[i][1];
cin>>m;
for(int i=1;i<=n;i++)d[i]=f[i][1]=f[i][2]=0x7fffffff/3;
for(int i=1;i<=m;i++){
int x,y;
cin>>x>>y;
f[i][1]=x;
f[i][2]=y;
w[i]=sqrt(pow(double(a[x][0]-a[y][0]),2)+pow(double(a[x][1]-a[y][1]),2));
}
cin>>s>>e;
d[s]=0;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(d[f[j][1]]+w[j]<d[f[j][2]]) d[f[j][2]]=d[f[j][1]]+w[j];
if(d[f[j][2]]+w[j]<d[f[j][1]]) d[f[j][1]]=d[f[j][2]]+w[j];
}
}
printf("%.2f\n",d[e]);
return 0;
}