#include namespace zawa { using i16 = std::int16_t; using i32 = std::int32_t; using i64 = std::int64_t; using i128 = __int128_t; using u8 = std::uint8_t; using u16 = std::uint16_t; using u32 = std::uint32_t; using u64 = std::uint64_t; using usize = std::size_t; } // namespace zawa namespace zawa { void SetFastIO() { std::cin.tie(nullptr)->sync_with_stdio(false); } void SetPrecision(u32 dig) { std::cout << std::fixed << std::setprecision(dig); } } // namespace zawa using namespace zawa; const long long mod{998244353}; long long f(int n) { long long res{1}; for (int i{1} ; i <= n ; i++) { res = (res * i) % mod; } return res; } int main() { SetFastIO(); int n; std::cin >> n; std::vector> a(n + n); for (int i{} ; i < n ; i++) { std::cin >> a[i].first; a[i].second = 0; } for (int i{} ; i < n ; i++) { std::cin >> a[i + n].first; a[i].second = 1; } std::sort(a.begin(), a.end()); int x{n}, y{n}; for (int i{} ; i < n ; i++) { if (a[i].second == 0) x--; else y--; } long long ans{(f(x) * f(y)) % mod}; std::cout << ans << '\n'; }