#include #include #include #include #include #include #include "math.h" #include #include #include #define ifor(i,a,b) for (int i=(a);i<(b);i++) #define rfor(i,a,b) for (int i=(b)-1;i>=(a);i--) #define rep(i,n) for (int i=0;i<(n);i++) #define rrep(i,n) for (int i=(n)-1;i>=0;i--) using namespace std; typedef long double ld; typedef long long int lli; typedef complex P; const double eps = 1e-11; int vex[4]={1,0,-1,0}; int vey[4]={0,1,0,-1}; typedef vector Vec; typedef vector vec; typedef vector MAT; typedef vector mat; #define UF_MAX 1005 struct UFind{ int par[UF_MAX]; int rank[UF_MAX]; void init(int n){ rep(i,n){ par[i] = i; rank[i] = 0; } } int find(int x){ if(par[x]== x){ return x; }else { return par[x]= find(par[x]); } } void unite (int x,int y){ x =find(x); y = find(y); if(x==y)return; if(rank[x]> N; rep(i,N)cin>>x[i]>>y[i]; f.init(N); rep(i,N)rep(j,i){ dis[i][j] = sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j])); dis[j][i] = dis[i][j]; if(dis[i][j]<=10)f.unite(i,j); } double ans = 0; rep(i,N)rep(j,i){ if(f.same(i,j))ans=max(ans,dis[i][j]); } if(N==0)cout<<1<