#include <algorithm>
#include <bitset>
#include <cassert>
#include <cmath>
#include <complex>
#include <cstdio>
#include <cstring>
#include <deque>
#include <fstream>
#include <functional>
#include <iostream>
#include <map>
#include <queue>
#include <random>
#include <set>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>
#define popcount __builtin_popcount
using namespace std;
typedef long long int ll;
typedef pair<int, int> P;
const ll INF = 1e18;
int main() {
  int n;
  cin >> n;
  ll l[5010], r[5010];
  vector<int> ind(n);
  iota(ind.begin(), ind.end(), 0);
  for (int i = 0; i < n; i++)
    cin >> l[i] >> r[i];
  if (n == 1) {
    cout << 0 << endl;
    return 0;
  }
  sort(ind.begin(), ind.end(),
       [&](int i, int j) { return l[i] + r[i] > l[j] + r[j]; });
  ll dp[2][5010];
  dp[0][0] = 0;
  for (int i = 0; i < n; i++) {
    int t = ind[i];
    for (int j = 0; j <= i + 1; j++)
      dp[(i + 1) & 1][j] = INF;
    for (int j = 0; j <= i; j++) {
      dp[(i + 1) & 1][j] = min(dp[(i + 1) & 1][j],
                               dp[i & 1][j] + (i - j) * (l[t] + r[t]) + l[t]);
      dp[(i + 1) & 1][j + 1] =
          min(dp[(i + 1) & 1][j + 1], dp[i & 1][j] + j * (l[t] + r[t]) + r[t]);
    }
  }
  ll ans = INF;
  for (int i = 0; i <= n; i++)
    ans = min(ans, dp[n & 1][i]);
  if (n % 2 == 0) {
    cout << ans << endl;
    return 0;
  }
  ll dp2[2][2][5010];
  dp2[0][0][0] = 0, dp2[0][1][0] = INF;
  for (int i = 0; i < n; i++) {
    int t = ind[i];
    for (int j = 0; j <= i + 1; j++)
      dp2[(i + 1) & 1][0][j] = dp2[(i + 1) & 1][1][j] = INF;
    for (int j = 0; j <= i; j++) {
      for (int k = 0; k < 2; k++) {
        dp2[(i + 1) & 1][k][j] =
            min(dp2[(i + 1) & 1][k][j],
                dp2[i & 1][k][j] + (i - j) * (l[t] + r[t]) + l[t]);
        dp2[(i + 1) & 1][k][j + 1] =
            min(dp2[(i + 1) & 1][k][j + 1],
                dp2[i & 1][k][j] + j * (l[t] + r[t]) + r[t]);
      }
      dp2[(i + 1) & 1][1][j] =
          min(dp2[(i + 1) & 1][1][j],
              dp2[i & 1][0][j] + (n - 1) / 2 * (l[t] + r[t]));
    }
  }
  ans = min(ans, dp2[n & 1][1][(n - 1) / 2]);
  cout << ans << endl;
  return 0;
}