#include <bits/stdc++.h>
using namespace std;
const int DIM = 1e5 + 5;
int anc[DIM];
struct str {
  int x, y, z;
} pts[DIM], edg[DIM << 1];
int getroot(int x) { return (anc[x] < 0) ? x : getroot(anc[x]); }
int main(void) {
  ios::sync_with_stdio(false);
  int n, m = 0;
  long long ans = 0;
  cin >> n;
  for (int i = 1; i <= n; ++i) {
    cin >> pts[i].x >> pts[i].y;
    pts[i].z = i;
    anc[i] = -1;
  }
  sort(pts + 1, pts + n + 1, [](str p1, str p2) { return p1.x < p2.x; });
  for (int i = 1; i < n; ++i)
    edg[++m] = {pts[i].z, pts[i + 1].z, pts[i + 1].x - pts[i].x};
  sort(pts + 1, pts + n + 1, [](str p1, str p2) { return p1.y < p2.y; });
  for (int i = 1; i < n; ++i)
    edg[++m] = {pts[i].z, pts[i + 1].z, pts[i + 1].y - pts[i].y};
  sort(edg + 1, edg + m + 1, [](str p1, str p2) { return p1.z < p2.z; });
  for (int i = 1; i <= m; ++i) {
    int x = getroot(edg[i].x), y = getroot(edg[i].y);
    if (x == y)
      continue;
    ans += edg[i].z;
    if (anc[x] > anc[y])
      swap(x, y);
    anc[x] += anc[y];
    anc[y] = x;
  }
  cout << ans;
  return 0;
}
