結果
問題 |
No.2615 ペアの作り方
|
ユーザー |
![]() |
提出日時 | 2024-01-26 21:29:23 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 46 ms / 2,000 ms |
コード長 | 1,220 bytes |
コンパイル時間 | 2,273 ms |
コンパイル使用メモリ | 198,924 KB |
最終ジャッジ日時 | 2025-02-18 22:57:18 |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 21 |
ソースコード
#include <bits/stdc++.h> 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<std::pair<int, int>> 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'; }