// #pragma GCC target("avx2") // #pragma GCC optimize("O3") // #pragma GCC optimize("unroll-loops") #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll = long long; using pii = pair; using pll = pair; using pli = pair; #define TEST cerr << "TEST" << endl #define AMARI 998244353 // #define AMARI 1000000007 #define TIME_LIMIT 1980000 #define el '\n' #define El '\n' #define MULTI_TEST_CASE false void solve(void) { //問題を見たらまず「この問題設定から言えること」をいっぱい言ってみる //一個解答に繋がりそうな解法が見えても、実装や細かい考察に時間がかかりそうなら別の方針やを考えてみる //特に添え字周りはそのままやると面倒&言い換えが有効なことが多いので書き始める前にじっくり考える int n; cin >> n; vector x(n),y(n); for(int i = 0; i < n; i++)cin >> x[i]; for(int i = 0; i < n; i++)cin >> y[i]; if(*max_element(x.begin(),x.end()) < *min_element(y.begin(),y.end()) || *min_element(x.begin(),x.end()) > *max_element(y.begin(),y.end())){ ll ans = 1; for(int i = 1; i <= n; i++){ ans *= (ll)i; ans %= AMARI; } cout << ans << el; return; } sort(x.begin(),x.end()); sort(y.rbegin(),y.rend()); int cnt = 0; for(int i = 0; i < n; i++){ if(x[i] < y[i])cnt++; } //cerr << El; ll ans = 1; for(int i = 1; i <= cnt; i++){ ans *= (ll)i; ans %= AMARI; } for(int i = 1; i <= n - cnt; i++){ ans *= (ll)i; ans %= AMARI; } cout << ans << el; return; } void calc(void) { return; } signed main(void) { cin.tie(nullptr); ios::sync_with_stdio(false); calc(); int t = 1; if(MULTI_TEST_CASE) cin >> t; while(t--) { solve(); } return 0; }