Submission #66653512


Source Code Expand

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/modint>
using mint = atcoder::modint998244353;
#define rep(i, a, b) for (int i = (int)(a); i < (int)(b); i++)

int main(){
    int H, W;
    cin >> H >> W;
    if (H < W) swap(H, W);
    vector<mint> dpC(W + 1), dpS(W + 1);
    vector<mint> fact(W + 2, 1), invfact(W + 2, 1);
    rep(i, 0, W + 1) fact[i + 1] = fact[i] * (i + 1);
    invfact[W + 1] = fact[W + 1].inv();
    for (int i = W + 1; i > 0; i--) invfact[i - 1] = invfact[i] * i;
    dpC[0] = 1;
    rep(rp, 0, H){
        vector<mint> n_dpC(W + 1), n_dpS(W + 1);
        rep(i, 0, W + 1){
            rep(j, i, W + 1){
                n_dpC[j] += dpC[i] * invfact[j - i + 1] * (j + 1);
                n_dpS[j] += dpS[i] * invfact[j - i + 1] * (j + 1);
                n_dpS[j] += dpC[i] * i * invfact[j - i + 2] * (j + 1);
            }
        }
        swap(n_dpS, dpS);
        swap(n_dpC, dpC);
        rep(i, 0, W + 1) dpS[i] += dpC[i] * (W - i);
    }
    mint ans = 0;
    rep(i, 0, W + 1) ans += dpS[i] * invfact[W - i];
    rep(i, 1, W + 1) ans *= i;
    cout << ans.val() << "\n";
}

Submission Info

Submission Time
Task D - Limestone
User potato167
Language C++ 17 (gcc 12.2)
Score 1000
Code Size 1152 Byte
Status AC
Exec Time 346 ms
Memory 3596 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1000 / 1000
Status
AC × 3
AC × 34
Set Name Test Cases
Sample 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt
All 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_test_00.txt, 01_test_01.txt, 01_test_02.txt, 01_test_03.txt, 01_test_04.txt, 01_test_05.txt, 01_test_06.txt, 01_test_07.txt, 01_test_08.txt, 01_test_09.txt, 01_test_10.txt, 01_test_11.txt, 01_test_12.txt, 01_test_13.txt, 01_test_14.txt, 01_test_15.txt, 01_test_16.txt, 01_test_17.txt, 01_test_18.txt, 01_test_19.txt, 01_test_20.txt, 01_test_21.txt, 01_test_22.txt, 01_test_23.txt, 01_test_24.txt, 01_test_25.txt, 01_test_26.txt, 01_test_27.txt, 01_test_28.txt, 01_test_29.txt, 01_test_30.txt
Case Name Status Exec Time Memory
00_sample_00.txt AC 1 ms 3420 KiB
00_sample_01.txt AC 1 ms 3368 KiB
00_sample_02.txt AC 28 ms 3492 KiB
01_test_00.txt AC 9 ms 3428 KiB
01_test_01.txt AC 9 ms 3520 KiB
01_test_02.txt AC 13 ms 3368 KiB
01_test_03.txt AC 16 ms 3460 KiB
01_test_04.txt AC 27 ms 3468 KiB
01_test_05.txt AC 67 ms 3468 KiB
01_test_06.txt AC 109 ms 3420 KiB
01_test_07.txt AC 251 ms 3476 KiB
01_test_08.txt AC 156 ms 3428 KiB
01_test_09.txt AC 49 ms 3468 KiB
01_test_10.txt AC 51 ms 3524 KiB
01_test_11.txt AC 24 ms 3436 KiB
01_test_12.txt AC 13 ms 3492 KiB
01_test_13.txt AC 7 ms 3432 KiB
01_test_14.txt AC 8 ms 3432 KiB
01_test_15.txt AC 7 ms 3416 KiB
01_test_16.txt AC 11 ms 3428 KiB
01_test_17.txt AC 334 ms 3396 KiB
01_test_18.txt AC 339 ms 3596 KiB
01_test_19.txt AC 331 ms 3496 KiB
01_test_20.txt AC 337 ms 3468 KiB
01_test_21.txt AC 334 ms 3496 KiB
01_test_22.txt AC 333 ms 3472 KiB
01_test_23.txt AC 334 ms 3480 KiB
01_test_24.txt AC 343 ms 3384 KiB
01_test_25.txt AC 338 ms 3596 KiB
01_test_26.txt AC 335 ms 3540 KiB
01_test_27.txt AC 1 ms 3368 KiB
01_test_28.txt AC 12 ms 3428 KiB
01_test_29.txt AC 12 ms 3424 KiB
01_test_30.txt AC 346 ms 3476 KiB