QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#837629 | #1257. Easy One | liwuyou | AC ✓ | 39ms | 75852kb | C++14 | 1.5kb | 2024-12-30 10:13:28 | 2024-12-30 10:13:29 |
Judging History
answer
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 2000005, mod = 998244353;
int dp[N];
int fact[N], infact[N], inv[N], dfact[N];
int qmi(int x, int y) {
int ans = 1;
while(y) {
if(y & 1) {
(ans *= x) %= mod;
}
(x *= x) %= mod;
y >>= 1;
}
return ans;
}
int C(int n, int m) {
if (n < m || m < 0) return 0;
return fact[n] * infact[m] % mod * infact[n - m] % mod;
}
void solve() {
int a, b, t;
cin >> a >> b >> t;
if (t % 2 || (b - a) * 2 > t) {
cout << "0\n";
return;
}
if(a == b && t == 0) {
cout << "1\n";
return;
}
if(b < a) {
swap(a, b);
}
b -= a, t /= 2;
dp[0] = C(t, b) * dfact[2 * t - 1] % mod;
for(int i = 1; i <= a; i++) {
dp[i] = ((2 * (-1 + b + i) * i - (b - 1) + (1 + t) * t) % mod * dp[i - 1] % mod + (i * (-i - b + 2) - (1 - b)) % mod * (i >= 2 ? dp[i - 2] : 0) % mod) % mod * inv[i] % mod * inv[i + b] % mod;
}
cout << (dp[a] + mod) % mod << '\n';
}
signed main() {
inv[1] = fact[0] = fact[1] = infact[0] = infact[1] = dfact[0] = dfact[1] = 1;
for(int i = 2; i < N; i++) {
fact[i] = fact[i - 1] * i % mod;
dfact[i] = dfact[i - 2] * i % mod;
}
infact[N - 1] = qmi(fact[N - 1], mod - 2);
for(int i = N - 2; i; i--) {
infact[i] = infact[i + 1] * (i + 1) % mod;
}
for(int i = 2; i < N; i++) {
inv[i] = fact[i - 1] * infact[i] % mod;
}
int t = 1;
// cin >> t;
while(t--) {
solve();
}
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 12ms
memory: 67408kb
input:
0 0 4
output:
3
result:
ok 1 number(s): "3"
Test #2:
score: 0
Accepted
time: 17ms
memory: 67152kb
input:
1 4 6
output:
60
result:
ok 1 number(s): "60"
Test #3:
score: 0
Accepted
time: 21ms
memory: 67416kb
input:
10 10 9
output:
0
result:
ok 1 number(s): "0"
Test #4:
score: 0
Accepted
time: 14ms
memory: 67452kb
input:
123 456 999
output:
0
result:
ok 1 number(s): "0"
Test #5:
score: 0
Accepted
time: 21ms
memory: 66264kb
input:
123 456 1000
output:
217690319
result:
ok 1 number(s): "217690319"
Test #6:
score: 0
Accepted
time: 16ms
memory: 67948kb
input:
0 999999 999999
output:
0
result:
ok 1 number(s): "0"
Test #7:
score: 0
Accepted
time: 18ms
memory: 68020kb
input:
0 499999 999998
output:
441249169
result:
ok 1 number(s): "441249169"
Test #8:
score: 0
Accepted
time: 21ms
memory: 67920kb
input:
999999 999999 999999
output:
0
result:
ok 1 number(s): "0"
Test #9:
score: 0
Accepted
time: 35ms
memory: 75852kb
input:
999999 999999 999998
output:
94264534
result:
ok 1 number(s): "94264534"
Test #10:
score: 0
Accepted
time: 30ms
memory: 70800kb
input:
500000 500000 10
output:
278436239
result:
ok 1 number(s): "278436239"
Test #11:
score: 0
Accepted
time: 8ms
memory: 69080kb
input:
123456 567890 999998
output:
200851796
result:
ok 1 number(s): "200851796"
Test #12:
score: 0
Accepted
time: 25ms
memory: 66728kb
input:
123456 565444 676767
output:
0
result:
ok 1 number(s): "0"
Test #13:
score: 0
Accepted
time: 16ms
memory: 66188kb
input:
999999 999999 121233
output:
0
result:
ok 1 number(s): "0"
Test #14:
score: 0
Accepted
time: 39ms
memory: 73992kb
input:
999999 999999 500000
output:
31235134
result:
ok 1 number(s): "31235134"
Test #15:
score: 0
Accepted
time: 28ms
memory: 75208kb
input:
999997 999993 500002
output:
289239002
result:
ok 1 number(s): "289239002"
Test #16:
score: 0
Accepted
time: 22ms
memory: 66996kb
input:
99999 999999 990000
output:
0
result:
ok 1 number(s): "0"
Test #17:
score: 0
Accepted
time: 8ms
memory: 67920kb
input:
0 499999 999996
output:
0
result:
ok 1 number(s): "0"
Test #18:
score: 0
Accepted
time: 30ms
memory: 66924kb
input:
0 0 0
output:
1
result:
ok 1 number(s): "1"
Test #19:
score: 0
Accepted
time: 8ms
memory: 67872kb
input:
0 0 1000000
output:
765860359
result:
ok 1 number(s): "765860359"
Test #20:
score: 0
Accepted
time: 21ms
memory: 66492kb
input:
0 1000000 0
output:
0
result:
ok 1 number(s): "0"
Test #21:
score: 0
Accepted
time: 18ms
memory: 66260kb
input:
0 1000000 1000000
output:
0
result:
ok 1 number(s): "0"
Test #22:
score: 0
Accepted
time: 21ms
memory: 67848kb
input:
1000000 0 0
output:
0
result:
ok 1 number(s): "0"
Test #23:
score: 0
Accepted
time: 25ms
memory: 68100kb
input:
1000000 0 1000000
output:
0
result:
ok 1 number(s): "0"
Test #24:
score: 0
Accepted
time: 15ms
memory: 66636kb
input:
1000000 1000000 0
output:
1
result:
ok 1 number(s): "1"
Test #25:
score: 0
Accepted
time: 35ms
memory: 74072kb
input:
1000000 1000000 1000000
output:
657734828
result:
ok 1 number(s): "657734828"
Test #26:
score: 0
Accepted
time: 19ms
memory: 66912kb
input:
42153 66017 282528
output:
721725208
result:
ok 1 number(s): "721725208"
Test #27:
score: 0
Accepted
time: 19ms
memory: 67148kb
input:
920225 95518 314790
output:
0
result:
ok 1 number(s): "0"
Test #28:
score: 0
Accepted
time: 19ms
memory: 67960kb
input:
761297 88021 384736
output:
0
result:
ok 1 number(s): "0"
Test #29:
score: 0
Accepted
time: 20ms
memory: 68300kb
input:
639368 117522 379998
output:
0
result:
ok 1 number(s): "0"
Test #30:
score: 0
Accepted
time: 15ms
memory: 68112kb
input:
480440 110024 375261
output:
0
result:
ok 1 number(s): "0"
Test #31:
score: 0
Accepted
time: 12ms
memory: 66648kb
input:
321512 138841 445207
output:
0
result:
ok 1 number(s): "0"
Test #32:
score: 0
Accepted
time: 12ms
memory: 66064kb
input:
199583 168342 440469
output:
0
result:
ok 1 number(s): "0"
Test #33:
score: 0
Accepted
time: 23ms
memory: 66756kb
input:
40655 160844 473416
output:
740459120
result:
ok 1 number(s): "740459120"
Test #34:
score: 0
Accepted
time: 16ms
memory: 66600kb
input:
881728 190346 468679
output:
0
result:
ok 1 number(s): "0"
Test #35:
score: 0
Accepted
time: 29ms
memory: 69224kb
input:
722801 219847 538624
output:
0
result:
ok 1 number(s): "0"
Test #36:
score: 0
Accepted
time: 18ms
memory: 66712kb
input:
140788 795655 506181
output:
0
result:
ok 1 number(s): "0"
Test #37:
score: 0
Accepted
time: 31ms
memory: 72360kb
input:
981861 788157 538442
output:
985234443
result:
ok 1 number(s): "985234443"
Test #38:
score: 0
Accepted
time: 20ms
memory: 67204kb
input:
822934 817658 571389
output:
0
result:
ok 1 number(s): "0"
Test #39:
score: 0
Accepted
time: 30ms
memory: 73220kb
input:
664006 772477 566652
output:
652080352
result:
ok 1 number(s): "652080352"
Test #40:
score: 0
Accepted
time: 25ms
memory: 66780kb
input:
542077 838977 636597
output:
0
result:
ok 1 number(s): "0"
Test #41:
score: 0
Accepted
time: 17ms
memory: 67372kb
input:
346150 868479 631860
output:
0
result:
ok 1 number(s): "0"
Test #42:
score: 0
Accepted
time: 22ms
memory: 67732kb
input:
224221 860981 664806
output:
0
result:
ok 1 number(s): "0"
Test #43:
score: 0
Accepted
time: 16ms
memory: 66660kb
input:
65293 890482 697068
output:
0
result:
ok 1 number(s): "0"
Test #44:
score: 0
Accepted
time: 32ms
memory: 74760kb
input:
943365 882985 729330
output:
351354011
result:
ok 1 number(s): "351354011"
Test #45:
score: 0
Accepted
time: 31ms
memory: 72444kb
input:
784437 911801 762276
output:
155945330
result:
ok 1 number(s): "155945330"
Test #46:
score: 0
Accepted
time: 27ms
memory: 69904kb
input:
491726 307429 671948
output:
73584358
result:
ok 1 number(s): "73584358"
Test #47:
score: 0
Accepted
time: 17ms
memory: 69448kb
input:
295799 336931 704894
output:
534052287
result:
ok 1 number(s): "534052287"
Test #48:
score: 0
Accepted
time: 23ms
memory: 68068kb
input:
173870 403431 700157
output:
0
result:
ok 1 number(s): "0"
Test #49:
score: 0
Accepted
time: 8ms
memory: 66464kb
input:
14942 395934 770103
output:
0
result:
ok 1 number(s): "0"
Test #50:
score: 0
Accepted
time: 18ms
memory: 66440kb
input:
893014 387751 765365
output:
0
result:
ok 1 number(s): "0"
Test #51:
score: 0
Accepted
time: 25ms
memory: 67376kb
input:
697087 380253 797627
output:
0
result:
ok 1 number(s): "0"
Test #52:
score: 0
Accepted
time: 24ms
memory: 69676kb
input:
575158 409755 830574
output:
261071668
result:
ok 1 number(s): "261071668"
Test #53:
score: 0
Accepted
time: 18ms
memory: 67292kb
input:
416230 476255 862835
output:
0
result:
ok 1 number(s): "0"
Test #54:
score: 0
Accepted
time: 15ms
memory: 68660kb
input:
257303 468757 895782
output:
86924988
result:
ok 1 number(s): "86924988"
Test #55:
score: 0
Accepted
time: 25ms
memory: 67916kb
input:
135374 498259 891045
output:
0
result:
ok 1 number(s): "0"
Test #56:
score: 0
Accepted
time: 28ms
memory: 72812kb
input:
805665 893203 838400
output:
263337727
result:
ok 1 number(s): "263337727"
Test #57:
score: 0
Accepted
time: 26ms
memory: 70084kb
input:
729675 247218 434658
output:
0
result:
ok 1 number(s): "0"
Test #58:
score: 0
Accepted
time: 32ms
memory: 72340kb
input:
609216 669503 870072
output:
202261436
result:
ok 1 number(s): "202261436"
Test #59:
score: 0
Accepted
time: 11ms
memory: 66596kb
input:
488756 514031 929421
output:
0
result:
ok 1 number(s): "0"
Test #60:
score: 0
Accepted
time: 21ms
memory: 67744kb
input:
691776 682039 463599
output:
0
result:
ok 1 number(s): "0"
Test #61:
score: 0
Accepted
time: 11ms
memory: 67500kb
input:
571316 404780 199469
output:
0
result:
ok 1 number(s): "0"
Test #62:
score: 0
Accepted
time: 29ms
memory: 68272kb
input:
774336 249308 958362
output:
0
result:
ok 1 number(s): "0"
Test #63:
score: 0
Accepted
time: 20ms
memory: 66556kb
input:
330396 671592 116476
output:
0
result:
ok 1 number(s): "0"
Test #64:
score: 0
Accepted
time: 19ms
memory: 72080kb
input:
533416 516121 753582
output:
113683116
result:
ok 1 number(s): "113683116"
Test #65:
score: 0
Accepted
time: 25ms
memory: 66860kb
input:
412956 684129 287759
output:
0
result:
ok 1 number(s): "0"
Test #66:
score: 0
Accepted
time: 15ms
memory: 67748kb
input:
292496 406870 347109
output:
0
result:
ok 1 number(s): "0"
Test #67:
score: 0
Accepted
time: 25ms
memory: 68112kb
input:
245891 134953 893416
output:
299302885
result:
ok 1 number(s): "299302885"
Test #68:
score: 0
Accepted
time: 29ms
memory: 67688kb
input:
125431 880717 952766
output:
0
result:
ok 1 number(s): "0"
Test #69:
score: 0
Accepted
time: 20ms
memory: 66668kb
input:
906207 725245 810423
output:
0
result:
ok 1 number(s): "0"
Test #70:
score: 0
Accepted
time: 22ms
memory: 68004kb
input:
207991 569774 546293
output:
0
result:
ok 1 number(s): "0"
Test #71:
score: 0
Accepted
time: 21ms
memory: 67212kb
input:
665287 992058 981707
output:
0
result:
ok 1 number(s): "0"
Test #72:
score: 0
Accepted
time: 32ms
memory: 73468kb
input:
868307 836586 139820
output:
168754021
result:
ok 1 number(s): "168754021"
Test #73:
score: 0
Accepted
time: 31ms
memory: 73540kb
input:
747847 882807 776926
output:
679383214
result:
ok 1 number(s): "679383214"