結果

問題 No.2565 はじめてのおつかい
ユーザー Lucagon
提出日時 2023-12-02 16:14:16
言語 PyPy3
(7.3.15)
結果
MLE  
実行時間 -
コード長 622 bytes
コンパイル時間 305 ms
コンパイル使用メモリ 82,048 KB
実行使用メモリ 852,248 KB
最終ジャッジ日時 2024-09-26 20:00:33
合計ジャッジ時間 3,638 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other MLE * 1 -- * 49
権限があれば一括ダウンロードができます

ソースコード

diff #

from collections import defaultdict
from sys import setrecursionlimit
setrecursionlimit(10**9)

def dfs(pos,r,visited):
    if pos in visited:
        if pos == 1 and n in visited and (n - 1) in visited:
            route.append((r+[pos],visited))

        return
    
    for i in g[pos]:
        dfs(i,r+[pos], visited | set([pos]))

n,m = map(int,input().split())
g = defaultdict(list)

for i in range(m):
    u,v = map(int,input().split())
    g[u].append(v)

visited = set()
route = []
dfs(1,[],set())

if route == []:
    print(-1)
    exit()

ans = 10**6
for i in route:
    ans = min(ans,len(i[0]) - 1)

print(ans)
0