結果

問題 No.2679 MODice
コンテスト
ユーザー H20
提出日時 2024-03-20 21:19:27
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
AC  
実行時間 97 ms / 2,000 ms
コード長 712 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 452 ms
コンパイル使用メモリ 20,696 KB
実行使用メモリ 15,360 KB
最終ジャッジ日時 2026-04-16 12:02:33
合計ジャッジ時間 3,369 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 15
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

N,K = map(int, input().split())
mod = 998244353
def matrix_multiply(A, B):
    """2つの行列AとBの乗算を行う"""
    result = [[0 for _ in range(len(B[0]))] for _ in range(len(A))]
    for i in range(len(A)):
        for j in range(len(B[0])):
            for k in range(len(B)):
                result[i][j] = (result[i][j] + (A[i][k] * B[k][j]))%mod
    return result

divsix = pow(6,mod-2,mod)

transition_matrix = [[divsix for _ in range(6)] for _ in range(6)]
ANS = [[divsix for _ in range(6)] for _ in range(6)]

while N:
    if N & 1:
        ANS = matrix_multiply(ANS, transition_matrix)
    transition_matrix = matrix_multiply(transition_matrix, transition_matrix)
    N //= 2
print(ANS[0][K])
0