#include <bits/stdc++.h>
#define all(x) (x).begin(), (x).end()
#define ll long long
using namespace std;
const ll MOD = 998244353;
ll pw(ll a, ll e, ll m) {
ll r = 1 % m; a %= m;
while (e > 0) {
if (e & 1) r = r * a % m;
a = a * a % m;
e >>= 1;
}
return r;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
int t;
cin >> t;
while (t--) {
int n;
cin >> n;
vector<ll> a(n), b(n);
for (int i = 0; i < n; ++i) cin >> a[i];
for (int i = 0; i < n; ++i) cin >> b[i];
if (n == 1) {
cout << 0 << '\n';
continue;
}
int N2 = n * n;
vector<pair<ll,ll>> pairs(N2);
int idx = 0;
for (int p = 0; p < n; ++p) {
for (int q = 0; q < n; ++q) {
pairs[idx++] = {b[p], b[q]};
}
}
sort(all(pairs), [](const pair<ll,ll>& x, const pair<ll,ll>& y){
return x.second * y.first < y.second * x.first;
});
ll total = 0;
for (int i = 0; i < n; ++i) {
for (int j = i + 1; j < n; ++j) {
ll ai = a[i], aj = a[j];
int lo = 0, hi = N2;
while (lo < hi) {
int mid = (lo + hi) >> 1;
if (pairs[mid].second * aj < pairs[mid].first * ai) lo = mid + 1;
else hi = mid;
}
ll cnt = lo;
if (ai > aj) cnt -= n;
total = (total + cnt) % MOD;
}
}
ll denom = (ll)n * (n - 1) % MOD;
ll ans = total % MOD * pw(denom, MOD - 2, MOD) % MOD;
cout << ans << '\n';
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNkZWZpbmUgYWxsKHgpICh4KS5iZWdpbigpLCAoeCkuZW5kKCkKI2RlZmluZSBsbCBsb25nIGxvbmcKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCmNvbnN0IGxsIE1PRCA9IDk5ODI0NDM1MzsKCmxsIHB3KGxsIGEsIGxsIGUsIGxsIG0pIHsKICAgIGxsIHIgPSAxICUgbTsgYSAlPSBtOwogICAgd2hpbGUgKGUgPiAwKSB7CiAgICAgICAgaWYgKGUgJiAxKSByID0gciAqIGEgJSBtOwogICAgICAgIGEgPSBhICogYSAlIG07CiAgICAgICAgZSA+Pj0gMTsKICAgIH0KICAgIHJldHVybiByOwp9CgppbnQgbWFpbigpIHsKICAgIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oZmFsc2UpOwogICAgY2luLnRpZShudWxscHRyKTsKICAgIAogICAgaW50IHQ7CiAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBpbnQgbjsKICAgICAgICBjaW4gPj4gbjsKICAgICAgICB2ZWN0b3I8bGw+IGEobiksIGIobik7CiAgICAgICAgZm9yIChpbnQgaSA9IDA7IGkgPCBuOyArK2kpIGNpbiA+PiBhW2ldOwogICAgICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbjsgKytpKSBjaW4gPj4gYltpXTsKICAgICAgICAKICAgICAgICBpZiAobiA9PSAxKSB7CiAgICAgICAgICAgIGNvdXQgPDwgMCA8PCAnXG4nOwogICAgICAgICAgICBjb250aW51ZTsKICAgICAgICB9CiAgICAgICAgCiAgICAgICAgaW50IE4yID0gbiAqIG47CiAgICAgICAgdmVjdG9yPHBhaXI8bGwsbGw+PiBwYWlycyhOMik7CiAgICAgICAgaW50IGlkeCA9IDA7CiAgICAgICAgZm9yIChpbnQgcCA9IDA7IHAgPCBuOyArK3ApIHsKICAgICAgICAgICAgZm9yIChpbnQgcSA9IDA7IHEgPCBuOyArK3EpIHsKICAgICAgICAgICAgICAgIHBhaXJzW2lkeCsrXSA9IHtiW3BdLCBiW3FdfTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICAKICAgICAgICBzb3J0KGFsbChwYWlycyksIFtdKGNvbnN0IHBhaXI8bGwsbGw+JiB4LCBjb25zdCBwYWlyPGxsLGxsPiYgeSl7CiAgICAgICAgICAgIHJldHVybiB4LnNlY29uZCAqIHkuZmlyc3QgPCB5LnNlY29uZCAqIHguZmlyc3Q7CiAgICAgICAgfSk7CiAgICAgICAgCiAgICAgICAgbGwgdG90YWwgPSAwOwogICAgICAgIAogICAgICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbjsgKytpKSB7CiAgICAgICAgICAgIGZvciAoaW50IGogPSBpICsgMTsgaiA8IG47ICsraikgewogICAgICAgICAgICAgICAgbGwgYWkgPSBhW2ldLCBhaiA9IGFbal07CiAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgIGludCBsbyA9IDAsIGhpID0gTjI7CiAgICAgICAgICAgICAgICB3aGlsZSAobG8gPCBoaSkgewogICAgICAgICAgICAgICAgICAgIGludCBtaWQgPSAobG8gKyBoaSkgPj4gMTsKICAgICAgICAgICAgICAgICAgICBpZiAocGFpcnNbbWlkXS5zZWNvbmQgKiBhaiA8IHBhaXJzW21pZF0uZmlyc3QgKiBhaSkgbG8gPSBtaWQgKyAxOwogICAgICAgICAgICAgICAgICAgIGVsc2UgaGkgPSBtaWQ7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgIGxsIGNudCA9IGxvOwogICAgICAgICAgICAgICAgaWYgKGFpID4gYWopIGNudCAtPSBuOwogICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICB0b3RhbCA9ICh0b3RhbCArIGNudCkgJSBNT0Q7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICAgICAgCiAgICAgICAgbGwgZGVub20gPSAobGwpbiAqIChuIC0gMSkgJSBNT0Q7CiAgICAgICAgbGwgYW5zID0gdG90YWwgJSBNT0QgKiBwdyhkZW5vbSwgTU9EIC0gMiwgTU9EKSAlIE1PRDsKICAgICAgICAKICAgICAgICBjb3V0IDw8IGFucyA8PCAnXG4nOwogICAgfQogICAgCiAgICByZXR1cm4gMDsKfQo=