#include <bits/stdc++.h>
using namespace std;
#define mod 998244353
#define MOD 1000000007
#define inf 0x3f3f3f3f
#define linf 0x3f3f3f3f3f3f3f3fll
typedef long long ll;
typedef pair<int, int> pii;
typedef unsigned long long ull;
const int maxn = 1e5 + 10;
int a[maxn], b[maxn];
int main() {
  int n;
  scanf("%d", &n);
  for (int i = 0; i < n; i++)
    scanf("%d", &a[i]);
  sort(a, a + n);
  for (int i = 0; i < n; i++)
    scanf("%d", &b[i]);
  sort(b, b + n);
  ll ans = 1;
  int prea = 0, preb = 0;
  int ca = 0, cb = 0;
  while (ca < n && cb < n) {
    if (a[ca] < b[cb]) {
      if (preb != 0) {
        ans = ans * 1ll * preb % MOD;
        preb--;
      } else {
        prea++;
      }
      ca++;
    } else {
      if (prea != 0) {
        ans = ans * 1ll * prea % MOD;
        prea--;
      } else {
        preb++;
      }
      cb++;
    }
  }
  while (ca < n) {
    ans = ans * 1ll * preb % MOD;
    preb--;
    ca++;
  }
  while (cb < n) {
    ans = ans * 1ll * prea % MOD;
    prea--;
    cb++;
  }
  printf("%lld\n", ans);
  return 0;
}