結果
| 問題 | No.3571 Sigma Problems Problem |
| ユーザー |
|
| 提出日時 | 2026-06-11 22:29:39 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 367 ms / 2,000 ms |
| コード長 | 700 bytes |
| 記録 | |
| コンパイル時間 | 245 ms |
| コンパイル使用メモリ | 85,096 KB |
| 実行使用メモリ | 81,408 KB |
| 最終ジャッジ日時 | 2026-06-11 22:29:49 |
| 合計ジャッジ時間 | 6,306 ms |
|
ジャッジサーバーID (参考情報) |
judge3_1 / judge2_0 |
| 純コード判定待ち |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 20 |
ソースコード
# ちゃんと時間内に解いたぞ!
# modをとらなかったら、Aのそれぞれの要素がN-1回ずつ足される
# その寄与の合計は M(M-1)/2 * M^(N-1) * N * (N-1) か?
# あとはM以上を数えるということ
# 1ヶ所のfの寄与を考えると、そんなのは明らかに M^(N-2) * M(M-1)/2
MOD = 998244353
INV2 = pow(2, -1, MOD)
def solve():
N, M = map(int, input().split())
if N == 1 or M == 1:
print(0)
return
res = M * (M - 1) * INV2 * pow(M, N - 1, MOD) * N * (N - 1) % MOD
res -= M * pow(M, N - 2, MOD) * M * (M - 1) * INV2 * N * (N - 1) * INV2 % MOD
res %= MOD
print(res)
for _ in range(int(input())):
solve()