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 |
|
|
| 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 |