結果
| 問題 |
No.2529 Treasure Hunter
|
| コンテスト | |
| ユーザー |
titia
|
| 提出日時 | 2023-11-04 01:56:43 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 951 ms / 2,000 ms |
| コード長 | 824 bytes |
| コンパイル時間 | 132 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 10,752 KB |
| 最終ジャッジ日時 | 2024-09-25 21:50:44 |
| 合計ジャッジ時間 | 21,181 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 22 |
ソースコード
import sys
input = sys.stdin.readline
mod=998244353
T=int(input())
for tests in range(T):
M,N=map(int,input().split())
k02=0
for i in range(M):
if i==0:
k02+=max(0,M-3)
else:
k02+=max(0,M-i-2)
k12=0
for i in range(1,M):
k12+=max(0,M-i-2)
k22=0
for i in range(1,M):
if i==0 or i==2:
continue
else:
k22+=max(0,M-i-2)
DP=[1,0,0]
for i in range(N):
NDP=[0,0,0]
NDP[0]+=DP[0]
NDP[1]+=DP[0]*M
NDP[2]+=DP[0]*k02
NDP[0]+=DP[1]
NDP[1]+=DP[1]*max(0,M-1)
NDP[2]+=DP[1]*k12
NDP[0]+=DP[2]
NDP[1]+=DP[2]*max(0,M-2)
NDP[2]+=DP[2]*k22
DP=[dp%mod for dp in NDP]
#print(DP)
print(sum(DP)%mod)
titia