#include <bits/stdc++.h>
using namespace std;
#define ref(i, x, y) for (int i = x; i <= y; ++i)
#define def(i, x, y) for (int i = x; i >= y; --i)
const int N = 101, mod = 1e9 + 7;
int n, nn, ans, a[N], b[N], f[N][N], g[N][N], f1[N][N], f2[N][N];
int main() {
  cin >> n;
  nn = n * 2 - 1;
  ref(i, 1, nn) cin >> a[i];
  sort(a + 1, a + nn + 1);
  ref(i, 1, n - 1) b[i] = (a[i] != a[i + 1]);
  ref(i, n + 1, nn) b[i] = (a[i] != a[i - 1]);
  b[n] = 1;
  f[0][0] = 1;
  ref(i, 1, n - 1) {
    memset(g, 0, sizeof g);
    ref(x, 0, nn) ref(y, 0, nn) if (f[x][y]) g[x + b[n - i]][y + b[n + i]] =
        f[x][y];
    memset(f, 0, sizeof f);
    memset(f1, 0, sizeof f1);
    memset(f2, 0, sizeof f2);
    ref(x, 0, nn) ref(y, 0, nn) if (g[x][y]) {
      (f1[x][y + 1] += g[x][y]) %= mod;
      (f2[x + 1][y] += g[x][y]) %= mod;
      (f[x][y] += g[x][y]) %= mod;
    }
    def(i, nn, 0) def(j, nn, 0) {
      (f1[i][j] += f1[i + 1][j]) %= mod;
      (f2[i][j] += f2[i][j + 1]) %= mod;
      (f[i][j] += f1[i + 1][j]) %= mod;
      (f[i][j] += f2[i][j + 1]) %= mod;
    }
  }
  ref(x, 0, nn) ref(y, 0, nn)(ans += f[x][y]) %= mod;
  cout << ans << endl;
}