QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#291087 | #4060. 多边形 | MoRanSky | 100 ✓ | 744ms | 148156kb | C++23 | 4.8kb | 2023-12-26 04:47:56 | 2023-12-26 04:47:57 |
Judging History
answer
// Skyqwq
#include <bits/stdc++.h>
#define pb push_back
#define fi first
#define se second
#define mp make_pair
using namespace std;
typedef pair<int, int> PII;
typedef long long LL;
template <typename T> bool chkMax(T &x, T y) { return (y > x) ? x = y, 1 : 0; }
template <typename T> bool chkMin(T &x, T y) { return (y < x) ? x = y, 1 : 0; }
template <typename T> void inline read(T &x) {
int f = 1; x = 0; char s = getchar();
while (s < '0' || s > '9') { if (s == '-') f = -1; s = getchar(); }
while (s <= '9' && s >= '0') x = x * 10 + (s ^ 48), s = getchar();
x *= f;
}
typedef vector<int> Poly;
#define pb push_back
const int N = 1100000 + 5, P = 998244353, G = 3;
int A[N], rev[N], mod;
int lim = 1, len = 0, W[21][N];
int inline power(int a, int b, int Mod = P) {
int res = 1;
while (b) {
if (b & 1) res = (LL)res * a % Mod;
a = (LL)a * a % Mod;
b >>= 1;
}
return res;
}
int Gi = power(G, P - 2, P), inv2 = power(2, P - 2, P);
void inline NTT(int c[], int lim, int o) {
for (int i = 0; i < lim; i++)
if (i < rev[i]) swap(c[i], c[rev[i]]);
for (int k = 1, t = 0; k < lim; k <<= 1, t++) {
for (int i = 0; i < lim; i += (k << 1)) {
for (int j = 0; j < k; j++) {
int u = c[i + j], v = (LL)c[i + k + j] * W[t][j] % P;
c[i + j] = u + v >= P ? u + v - P : u + v;
c[i + j + k] = u - v < 0 ? u - v + P : u - v;
}
}
}
if (o == -1) {
reverse(c + 1, c + lim);
int inv = power(lim, P - 2, P);
for (int i = 0; i < lim; i++)
c[i] = (LL)c[i] * inv % P;
}
}
void inline setN(int n) {
lim = 1, len = 0;
while (lim < n) lim <<= 1, len++;
for (int i = 0; i < lim; i++)
rev[i] = (rev[i >> 1] >> 1) | ((i & 1) << (len - 1));
}
Poly inline NTT(Poly a, int o) {
int n = a.size();
for (int i = 0; i < n; i++) A[i] = a[i];
NTT(A, lim, o);
a.clear();
for (int i = 0; i < lim; i++) a.push_back(A[i]), A[i] = 0;
return a;
}
Poly inline mul (Poly a, Poly b, int newn = -1) {
if (newn == -1) newn = a.size() + b.size() - 1;
setN(a.size() + b.size() - 1);
Poly c = NTT(a, 1), d = NTT(b, 1);
for (int i = 0; i < lim; i++) c[i] = (LL)c[i] * d[i] % P;
d = NTT(c, -1); d.resize(newn);
return d;
}
// 用到的最大的 n
void inline init(int n) {
setN(2 * n);
for (int k = 1, t = 0; k < lim; k <<= 1, t++) {
int wn = power(G, (P - 1) / (k << 1));
W[t][0] = 1;
for (int j = 1; j < k; j++) W[t][j] = (LL)W[t][j - 1] * wn % P;
}
}
void inline add(int &x, int y) {
x += y;
if (x >= P) x -= P;
}
void inline del(int &x, int y) {
x -= y;
if (x < 0) x += P;
}
int fact[N << 1], infact[N << 1], inv[N << 1];
void inline preInv(int n) {
inv[1] = 1;
for (int i = 2; i <= n; i++)
inv[i] = ((LL)P - P / i) * inv[P % i] % P;
}
int inline C(int a, int b) {
if (a < b || a < 0 || b < 0) return 0;
return (LL)fact[a] * infact[b] % P * infact[a - b] % P;
}
int n, a[N], Ca[N];
void inline factPrework(int n) {
fact[0] = infact[0] = 1;
for (int i = 1; i <= n; i++) fact[i] = (LL)fact[i - 1] * i % P;
infact[n] = power(fact[n], P - 2);
for (int i = n - 1; i; i--) infact[i] = infact[i + 1] * (i + 1ll) % P;
for (int i = 1; i <= 500000; i++) Ca[i + 2] = 1ll * C(2 * i, i) * inv[i + 1] % P;
}
vector<int> ans;
// f(x + c)
Poly tr(Poly A, int c) {
int m = A.size();
Poly B(m, 0);
B[0] = 1;
for (int i = 1; i < m; i++) B[i] = 1ll * B[i - 1] * c % P;
for (int i = 0; i < m; i++) B[i] = 1ll * B[i] * infact[i] % P;
for (int i = 0; i < m; i++) A[i] = 1ll * A[i] * infact[i] % P;
Poly C = mul(A, B, m);
for (int i = 0; i < C.size(); i++) C[i] = 1ll * C[i] * fact[i] % P;
return C;
}
Poly calc(int a) {
int L = 2 * a;
vector<int> G(L + 1, 0);
for (int i = 0; i <= a; i++) G[i] = C(a, i);
// * (1 - x)
Poly nG = G;
for (int i = 0; i <= L; i++) {
if (i) del(nG[i - 1], G[i]);
}
G = nG;
G = tr(G, P - inv[2]);
Poly nF(G.size(), 0);
for (int i = 0; i < G.size(); i++)
if (i % 2 == 0) add(nF[i / 2], G[i]);
G = nF;
for (int i = 1; i < G.size(); i += 2) G[i] = (P - G[i]) % P;
G = tr(G, inv[4]);
G.resize(a + 1);
return G;
}
Poly F[N];
priority_queue<PII, vector<PII>, greater<PII> > q;
int main() {
init(5e5);
preInv(1e6);
factPrework(1e6);
read(n);
ans.pb(1);
for (int i = 1; i <= n; i++) {
read(a[i]); a[i]--;
}
for (int t = 1; t <= n; t++) {
F[t] = calc(a[t]);
q.push(mp(F[t].size(), t));
}
while (q.size() > 1) {
int u = q.top().se; q.pop();
int v = q.top().se; q.pop();
F[u] = mul(F[u], F[v]);
q.push(mp(F[u].size(), u));
}
int now = q.top().se;
int res = 0;
for (int i = 0; i < F[now].size(); i++)
add(res, 1ll * F[now][i] * Ca[n + i] % P);
printf("%d\n", res);
return 0;
}
详细
Test #1:
score: 5
Accepted
time: 26ms
memory: 105056kb
input:
20 2 12 7 4 19 19 18 5 46 10 5 13 31 2 7 37 1 22 9 31
output:
953244262
result:
ok 1 number(s): "953244262"
Test #2:
score: 5
Accepted
time: 19ms
memory: 104984kb
input:
100 1 3 4 1 6 12 2 9 2 3 4 2 3 1 1 1 1 4 1 2 2 1 3 5 1 1 3 1 5 1 2 1 8 7 1 1 1 1 3 2 4 9 2 2 6 3 4 2 2 4 1 5 1 1 1 4 1 6 1 3 5 2 3 8 3 1 1 1 9 1 4 2 2 1 2 1 2 1 2 2 1 1 3 6 1 1 8 2 1 8 1 1 2 5 5 8 3 2 12 1
output:
800045967
result:
ok 1 number(s): "800045967"
Test #3:
score: 5
Accepted
time: 23ms
memory: 103644kb
input:
10 540 120 18 449 758 805 167 1661 93 389
output:
994098496
result:
ok 1 number(s): "994098496"
Test #4:
score: 5
Accepted
time: 27ms
memory: 102212kb
input:
100 43 115 37 3 90 48 59 97 21 3 10 40 36 5 18 93 28 4 37 42 13 73 15 69 49 68 17 26 8 70 25 45 16 31 2 7 83 8 140 17 35 60 34 19 86 110 12 3 72 12 86 16 32 68 19 15 89 71 86 18 14 44 5 45 105 15 72 48 17 397 37 105 11 19 37 211 81 77 48 35 19 121 7 3 54 32 123 38 23 39 21 15 97 34 45 93 38 134 10 77
output:
72510855
result:
ok 1 number(s): "72510855"
Test #5:
score: 5
Accepted
time: 20ms
memory: 102364kb
input:
299 11 24 32 8 14 4 28 15 17 3 5 3 2 94 19 4 23 26 44 33 63 17 18 5 20 1 21 5 17 39 20 4 8 4 29 2 3 22 17 31 9 1 15 18 13 6 1 9 13 19 6 14 63 8 13 65 3 24 9 11 17 5 16 7 30 15 19 12 13 66 10 7 13 42 4 12 8 4 9 29 4 25 1 5 3 5 47 8 9 11 43 23 9 5 26 1 4 40 14 11 5 3 4 8 27 20 35 5 19 3 11 3 13 10 23 ...
output:
59062414
result:
ok 1 number(s): "59062414"
Test #6:
score: 5
Accepted
time: 31ms
memory: 103648kb
input:
300 6 5 31 12 13 18 6 13 6 2 41 42 33 1 12 12 10 9 38 7 32 12 33 15 15 5 33 7 5 13 28 10 9 34 26 8 6 9 5 23 1 3 12 49 7 8 7 33 10 35 19 7 4 31 2 28 21 15 1 6 2 58 14 6 22 2 25 16 11 34 12 52 5 6 18 35 17 22 16 40 31 8 11 12 5 11 10 19 11 6 10 1 30 4 20 26 22 16 48 30 2 15 56 8 1 19 12 29 16 23 8 4 1...
output:
813084656
result:
ok 1 number(s): "813084656"
Test #7:
score: 5
Accepted
time: 13ms
memory: 102056kb
input:
499 9 6 20 7 3 5 3 3 6 11 16 14 9 16 5 14 7 26 2 5 9 3 14 15 12 18 2 16 3 23 6 4 20 4 4 1 17 17 2 9 10 3 3 22 2 3 4 6 12 9 48 18 1 53 2 16 3 5 18 1 9 2 4 17 3 3 21 6 28 17 14 5 1 6 19 3 39 2 10 2 3 3 1 12 9 8 9 10 27 2 2 4 1 11 20 2 1 4 1 9 6 4 4 3 2 12 2 1 4 14 16 8 21 27 8 8 10 30 1 17 30 2 22 1 1...
output:
941288569
result:
ok 1 number(s): "941288569"
Test #8:
score: 5
Accepted
time: 26ms
memory: 105184kb
input:
500 7 2 7 13 2 7 5 1 2 9 12 2 5 2 7 21 23 16 7 1 5 7 2 14 4 2 6 19 8 5 17 8 6 5 1 3 4 10 10 3 2 1 27 16 8 3 5 7 2 3 17 1 6 5 31 16 12 2 2 10 4 4 2 8 5 4 4 21 6 6 1 7 1 3 17 3 4 11 13 10 1 8 3 3 3 8 9 6 4 4 63 7 1 6 17 4 14 8 10 32 2 6 5 4 2 2 7 5 18 11 4 6 7 11 5 3 10 1 11 3 30 2 3 12 5 3 19 32 10 3...
output:
90948052
result:
ok 1 number(s): "90948052"
Test #9:
score: 5
Accepted
time: 28ms
memory: 107568kb
input:
999 1 1 2 1 5 4 7 1 8 10 10 2 13 3 3 4 3 5 2 15 1 2 2 1 4 3 3 2 1 5 3 3 4 3 5 1 6 4 7 5 5 19 1 1 4 6 1 6 4 2 4 1 1 1 3 2 1 8 1 4 4 5 1 3 9 9 1 1 3 8 1 9 6 11 2 8 1 2 4 5 2 10 2 1 3 1 8 2 2 4 4 2 1 5 22 1 3 6 1 14 7 9 2 5 6 7 1 6 1 10 2 6 3 1 1 2 3 2 5 14 13 5 1 3 13 1 2 4 5 1 1 3 7 5 6 1 2 5 7 1 4 9...
output:
957924176
result:
ok 1 number(s): "957924176"
Test #10:
score: 5
Accepted
time: 31ms
memory: 105200kb
input:
1000 7 4 6 6 3 10 6 2 11 1 7 2 1 1 4 5 10 2 21 1 4 12 8 1 9 2 3 2 3 1 11 3 6 14 7 1 2 6 11 2 2 1 3 3 2 2 2 17 4 5 9 14 1 12 9 5 5 3 5 2 1 10 9 7 2 5 6 1 1 6 1 1 3 3 6 11 8 2 2 5 1 3 3 19 7 1 1 1 2 3 6 4 5 17 9 8 5 2 5 3 8 14 1 1 6 4 2 1 23 6 1 1 1 8 1 3 9 5 3 11 2 2 4 13 7 3 12 3 4 3 3 6 1 7 7 2 15 ...
output:
500875813
result:
ok 1 number(s): "500875813"
Test #11:
score: 5
Accepted
time: 662ms
memory: 131568kb
input:
100 17410 97137 31290 2559 337 834 349 2112 6459 877 1705 7958 3711 1722 5021 9468 2869 2225 1380 1127 8017 2876 4567 536 1273 2561 627 2833 2289 1957 942 1835 6468 549 312 6435 16 2826 175 560 305 1392 12905 635 4360 8981 16313 17033 320 7166 13985 4366 4735 1264 229 1354 2479 7529 2812 913 1789 88...
output:
52527127
result:
ok 1 number(s): "52527127"
Test #12:
score: 5
Accepted
time: 653ms
memory: 134404kb
input:
101 24146 11890 18740 2812 2079 5936 10985 3246 255 4786 10412 413 571 9015 923 4984 2032 3563 6929 541 1196 609 5122 5513 1756 1657 4787 3177 5476 24391 418 14021 784 1843 5090 15303 599 5745 4987 572 8147 11495 5485 698 6029 14963 6719 12094 4496 2305 8354 2380 1360 574 3803 11668 1258 3400 7449 1...
output:
176953867
result:
ok 1 number(s): "176953867"
Test #13:
score: 5
Accepted
time: 672ms
memory: 137540kb
input:
1000 21039 55129 16652 263 959 648 1610 35 69 1 280 146 225 18 247 17 983 213 124 727 625 501 65 163 420 139 186 357 244 564 131 441 321 34 260 576 233 3 107 383 690 11 129 555 265 299 1064 34 803 99 489 420 254 579 668 77 372 523 1014 286 56 110 37 194 19 1537 214 9 153 195 284 50 1357 255 187 8 10...
output:
396709847
result:
ok 1 number(s): "396709847"
Test #14:
score: 5
Accepted
time: 667ms
memory: 138184kb
input:
1001 24149 26823 96474 354 433 548 1046 455 605 281 456 28 844 448 77 1156 248 158 310 113 1073 51 987 214 591 412 209 269 452 86 69 959 2220 500 190 174 809 722 140 210 408 40 114 86 204 40 61 651 167 344 440 1300 449 109 89 17 15 202 147 84 233 92 22 185 31 24 120 4 582 521 131 99 87 406 86 43 155...
output:
831188962
result:
ok 1 number(s): "831188962"
Test #15:
score: 5
Accepted
time: 721ms
memory: 145436kb
input:
5000 87723 44300 41919 21 1 7 6 9 43 185 13 31 17 1 26 33 49 30 19 13 33 30 65 62 39 2 94 2 247 89 138 202 19 49 65 26 106 102 119 15 79 25 10 94 47 217 14 78 79 53 87 18 179 105 357 90 64 61 30 12 137 26 149 44 128 96 83 113 36 127 32 66 73 3 38 7 81 309 56 80 20 15 20 42 58 61 142 66 287 221 85 27...
output:
69863836
result:
ok 1 number(s): "69863836"
Test #16:
score: 5
Accepted
time: 693ms
memory: 139640kb
input:
5001 18207 65535 46788 14 47 27 44 60 54 91 37 17 57 21 178 11 36 120 50 227 100 32 127 111 88 2 8 61 262 13 33 2 51 73 64 48 62 5 104 112 5 28 22 19 33 151 9 63 26 5 21 27 49 37 6 153 13 177 23 49 20 120 41 9 7 42 6 19 76 411 7 58 101 135 50 26 44 37 73 100 50 6 58 272 2 295 35 87 10 135 15 172 60 ...
output:
115196367
result:
ok 1 number(s): "115196367"
Test #17:
score: 5
Accepted
time: 690ms
memory: 143156kb
input:
10000 56495 32285 52736 44 31 65 8 30 36 5 31 29 12 90 20 80 26 1 3 2 42 34 91 1 75 127 54 5 40 9 13 26 12 47 2 9 9 104 44 24 45 28 1 1 36 41 24 12 16 22 43 2 6 2 87 11 49 13 52 18 77 18 39 16 45 35 35 143 31 139 37 14 13 1 40 3 3 32 8 1 52 9 20 76 5 14 3 43 41 23 25 67 2 4 17 83 44 41 30 47 70 25 6...
output:
357817820
result:
ok 1 number(s): "357817820"
Test #18:
score: 5
Accepted
time: 705ms
memory: 148156kb
input:
10001 9985 19836 28051 5 7 9 25 19 32 49 27 48 30 32 54 127 50 23 147 96 43 66 74 10 41 2 120 24 216 39 37 124 41 105 56 77 56 35 7 46 11 55 41 91 81 64 24 1 1 26 28 99 17 18 51 13 39 67 16 90 53 47 14 34 8 43 65 158 37 43 86 69 186 20 89 56 1 11 67 50 96 39 50 72 4 114 140 59 41 33 12 16 38 102 19 ...
output:
588504690
result:
ok 1 number(s): "588504690"
Test #19:
score: 5
Accepted
time: 731ms
memory: 146576kb
input:
100000 42183 92235 3069 1 1 5 1 3 8 3 1 6 4 5 6 2 1 2 3 4 5 1 2 3 8 3 1 2 1 4 4 2 9 1 4 7 1 1 10 2 2 5 1 1 2 6 2 3 8 4 4 7 2 4 9 6 1 7 1 2 3 4 3 3 3 3 6 5 2 1 4 3 3 2 8 15 1 1 4 4 2 3 1 4 5 1 1 7 2 1 1 1 4 5 1 1 4 12 4 3 3 6 7 6 2 1 4 1 10 1 4 2 3 13 2 2 3 4 2 1 3 1 5 1 11 3 1 6 4 5 5 3 6 2 1 1 1 1 ...
output:
585600950
result:
ok 1 number(s): "585600950"
Test #20:
score: 5
Accepted
time: 744ms
memory: 148052kb
input:
100001 76788 32127 11512 12 2 1 1 1 1 4 6 1 2 3 5 2 1 8 3 2 5 2 3 2 2 2 1 4 13 1 2 1 6 1 1 1 3 2 2 1 4 10 1 1 1 1 1 3 1 6 1 1 4 4 2 4 4 3 8 5 6 5 4 2 6 4 3 1 8 2 1 2 4 3 1 9 3 2 4 1 1 6 6 3 1 1 5 6 4 8 2 6 1 4 2 4 1 6 2 5 2 9 5 2 3 4 4 3 1 4 1 1 3 6 2 1 9 9 1 1 2 5 4 2 3 4 18 1 9 5 6 2 11 4 2 3 4 3 ...
output:
995217378
result:
ok 1 number(s): "995217378"