結果
問題 |
No.2683 Two Sheets
|
ユーザー |
![]() |
提出日時 | 2024-11-24 19:40:22 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 44 ms / 2,000 ms |
コード長 | 633 bytes |
コンパイル時間 | 374 ms |
コンパイル使用メモリ | 82,096 KB |
実行使用メモリ | 61,768 KB |
最終ジャッジ日時 | 2024-11-24 19:40:24 |
合計ジャッジ時間 | 1,681 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 13 |
ソースコード
H, W, A, B = map(int, input().split()) MOD = 998244353 def inverse(n, d): return n * pow(d, -1, MOD) % MOD sumH = 0 for i in range(1, A+1): if i < A: if A*2-i > H: continue sumH += (H-A+1-(A-i))*2*i%MOD sumH %= MOD else: sumH += (H-A+1)*i%MOD sumH %= MOD sumH = inverse(sumH, (H-A+1)**2%MOD) sumW = 0 for i in range(1, B+1): if i < B: if B*2-i > W: continue sumW += (W-B+1-(B-i))*2*i%MOD sumW %= MOD else: sumW += (W-B+1)*i%MOD sumW %= MOD sumW = inverse(sumW, (W-B+1)**2%MOD) print((A*B*2-sumH*sumW)%MOD)