#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define N 5010
#define INF 1000000000000000000LL
int n;
PII a[N];
ll f[N][2], g[N][2];
bool cmp(PII x, PII y) { return x.fi + x.se < y.fi + y.se; }
int main() {
  cin >> n;
  for (int i = 0; i < n; i++)
    cin >> a[i].fi >> a[i].se;
  sort(a, a + n, cmp);
  reverse(a, a + n);
  for (int i = 0; i < n; i++)
    f[i][0] = f[i][1] = INF;
  f[0][0] = 0;
  for (int i = 0; i < n; i++) {
    memcpy(g, f, sizeof f);
    for (int j = 0; j < n; j++)
      f[j][0] = f[j][1] = INF;
    if (n % 2 == 0) {
      for (int j = 0; j <= n / 2; j++) {
        if (j + 1 <= n / 2) {
          f[j + 1][0] =
              min(f[j + 1][0], g[j][0] + a[i].se + (ll)(a[i].fi + a[i].se) * j);
        }
        if (i - j + 1 <= n / 2) {
          f[j][0] = min(f[j][0],
                        g[j][0] + a[i].fi + (ll)(a[i].fi + a[i].se) * (i - j));
        }
      }
    } else {
      for (int j = 0; j <= n / 2; j++) {
        if (j + 1 <= n / 2) {
          f[j + 1][0] =
              min(f[j + 1][0], g[j][0] + a[i].se + (ll)(a[i].fi + a[i].se) * j);
          f[j + 1][1] =
              min(f[j + 1][1], g[j][1] + a[i].se + (ll)(a[i].fi + a[i].se) * j);
        }
        if (i - j + 1 <= n / 2) {
          f[j][0] = min(f[j][0],
                        g[j][0] + a[i].fi + (ll)(a[i].fi + a[i].se) * (i - j));
          f[j][1] = min(f[j][1],
                        g[j][1] + a[i].fi + (ll)(a[i].fi + a[i].se) * (i - j));
        }
        f[j][1] = min(f[j][1],
                      g[j][0] + (ll)a[i].fi * (n / 2) + (ll)a[i].se * (n / 2));
      }
    }
  }
  cout << f[n / 2][n % 2] << endl;
  return 0;
}