結果

問題 No.1340 おーじ君をさがせ
ユーザー ntuda
提出日時 2025-06-30 21:04:54
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 599 ms / 2,000 ms
コード長 598 bytes
コンパイル時間 575 ms
コンパイル使用メモリ 82,612 KB
実行使用メモリ 78,936 KB
最終ジャッジ日時 2025-06-30 21:05:08
合計ジャッジ時間 13,100 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 59
権限があれば一括ダウンロードができます

ソースコード

diff #

N, M, T = map(int, input().split())
AB = [list(map(int, input().split())) for _ in range(M)]
A = [[0] * N for _ in range(N)]
for a, b in AB:
    A[b][a] = 1
D = N

def mt(A, B):
    C = [[0] * D for _ in range(D)]
    for i in range(D):
        for j in range(D):
            tmp = 0
            for k in range(D):
                tmp |= A[i][k] * B[k][j]
            C[i][j] = tmp
    return C

X = [[0] * N for _ in range(N)]
for i in range(N):
    X[i][i] = 1

while T > 0:
    if T & 1:
        X = mt(A, X)
    A = mt(A, A)
    T >>= 1
ans = 0
for i in range(N):
    ans += X[i][0]
print(ans)
0