#include <bits/stdc++.h>
#define rep(i, a, b) for (int i = (a); i <= (b); ++i)
#define per(i, a, b) for (int i = (a); i >= (b); --i)
#define REP(i, n) for (int i = (0); i < (n); ++i)
#define cmin(x, y) ((y) < (x) ? (x) = (y) : 0)
#define cmax(x, y) ((y) > (x) ? (x) = (y) : 0)
#define sqr(x) ((x) * (x))
using namespace std;
const int N = 16;
double x[N], y[N], a[N], d[N][N], f[1 << N];
int n;
int main() {
  scanf("%d", &n);
  rep(i, 1, n) scanf("%lf%lf%lf", &x[i], &y[i], &a[i]);
  rep(i, 1, n) rep(j, 1, n) d[i][j] = sqrt(sqr(x[i] - x[j]) + sqr(y[i] - y[j]));
  fill(f, f + (1 << n), 1e99);
  f[0] = 0;
  REP(i, n) f[1 << i] = 0;
  REP(s, 1 << n)
  rep(i, 0, n - 1) rep(j, 0, n - 1) if ((s >> i & 1) && !(s >> j & 1))
      cmin(f[s | (1 << j)], f[s] + d[i + 1][j + 1]);
  REP(s, 1 << n) {
    f[s] = -f[s];
    REP(i, n) if (s >> i & 1) f[s] += a[i + 1];
    f[s] /= __builtin_popcount(s);
    for (int t = (s - 1) & s; t; t = (t - 1) & s)
      cmax(f[s], min(f[t], f[s - t]));
  }
  printf("%.10lf\n", f[(1 << n) - 1]);
  return 0;
}