提出 #53711095


ソースコード 拡げる

// LUOGU_RID: 159723041
#include <bits/stdc++.h>
using namespace std;
const int N = 5e5 + 5; 
const int P = 998244353; 

inline int poww(int a, int b) {
    int r = 1; 
    for (; b; b >>= 1, a = 1ll * a * a % P) if (b & 1) r = 1ll * r * a % P; 
    return r; 
}

int fac[N], ifac[N]; 
inline void initFac(void) {
    for (int i = fac[0] = 1; i < N; ++i) fac[i] = 1ll * fac[i - 1] * i % P; 
    ifac[N - 1] = poww(fac[N - 1], P - 2); 
    for (int i = N - 2; i >= 0; --i) ifac[i] = 1ll * ifac[i + 1] * (i + 1) % P; 
}
inline int C(int n, int m) {
    if (n < m || m < 0) return 0; 
    return 1ll * fac[n] * ifac[m] % P * ifac[n - m] % P; 
}

int n, k; 

int main(void) {
    initFac(); 
    cin >> n >> k; 
    if (k < n) return cout << "0\n", 0; 
    int ans = 0; 
    for (int R = 0; R <= k; ++R) {
        int B = k - R; 
        if (R < B) continue; 
        if (R >= B + n) { ans = (ans + C(k, R)) % P; continue; }
        if (R == B) --B; 
        ans = (ans + C(R + B, R) - C(R + B, 2 * R - n + 1)) % P; 
    }
    cout << (ans + P) % P << "\n"; 
    return 0;
}

提出情報

提出日時
問題 E - Ball Eat Chameleons
ユーザ james1BadCreeper
言語 C++ 17 (gcc 12.2)
得点 1200
コード長 1108 Byte
結果 AC
実行時間 9 ms
メモリ 7584 KiB

ジャッジ結果

セット名 Sample All
得点 / 配点 0 / 0 1200 / 1200
結果
AC × 5
AC × 39
セット名 テストケース
Sample s1.txt, s2.txt, s3.txt, s4.txt, s5.txt
All 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt, 31.txt, 32.txt, 33.txt, 34.txt, s1.txt, s2.txt, s3.txt, s4.txt, s5.txt
ケース名 結果 実行時間 メモリ
01.txt AC 9 ms 7360 KiB
02.txt AC 8 ms 7400 KiB
03.txt AC 8 ms 7520 KiB
04.txt AC 8 ms 7460 KiB
05.txt AC 8 ms 7404 KiB
06.txt AC 6 ms 7460 KiB
07.txt AC 7 ms 7404 KiB
08.txt AC 6 ms 7360 KiB
09.txt AC 6 ms 7460 KiB
10.txt AC 8 ms 7584 KiB
11.txt AC 8 ms 7464 KiB
12.txt AC 8 ms 7460 KiB
13.txt AC 8 ms 7436 KiB
14.txt AC 8 ms 7520 KiB
15.txt AC 7 ms 7544 KiB
16.txt AC 8 ms 7580 KiB
17.txt AC 8 ms 7460 KiB
18.txt AC 6 ms 7368 KiB
19.txt AC 8 ms 7356 KiB
20.txt AC 8 ms 7404 KiB
21.txt AC 8 ms 7384 KiB
22.txt AC 7 ms 7464 KiB
23.txt AC 7 ms 7456 KiB
24.txt AC 8 ms 7384 KiB
25.txt AC 8 ms 7396 KiB
26.txt AC 8 ms 7460 KiB
27.txt AC 8 ms 7400 KiB
28.txt AC 8 ms 7364 KiB
29.txt AC 7 ms 7580 KiB
30.txt AC 6 ms 7396 KiB
31.txt AC 6 ms 7404 KiB
32.txt AC 7 ms 7584 KiB
33.txt AC 8 ms 7380 KiB
34.txt AC 8 ms 7548 KiB
s1.txt AC 7 ms 7516 KiB
s2.txt AC 7 ms 7444 KiB
s3.txt AC 6 ms 7428 KiB
s4.txt AC 7 ms 7580 KiB
s5.txt AC 7 ms 7424 KiB