結果
問題 |
No.2565 はじめてのおつかい
|
ユーザー |
👑 |
提出日時 | 2023-11-03 15:52:18 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 587 ms / 2,000 ms |
コード長 | 886 bytes |
コンパイル時間 | 421 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 24,960 KB |
最終ジャッジ日時 | 2024-09-25 18:37:24 |
合計ジャッジ時間 | 17,747 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 50 |
ソースコード
from collections import deque INF = 1 << 60 N, M = map(int, input().split()) graph = [[] for _ in range(N)] for _ in range(M): u, v = map(int, input().split()) u -= 1 v -= 1 graph[u].append(v) def bfs(start, goal): visited = [False] * N que = deque([(start, 0)]) while que: now, d = que.popleft() for next in graph[now]: if visited[next] == True: continue if next == goal: return d + 1 visited[next] = True que.append((next, d + 1)) return INF # 町1 -> 町N-1 -> 町N -> 町1 の最短経路の長さ ans_1 = bfs(0, N-2) + bfs(N-2, N-1) + bfs(N-1, 0) # 町1 -> 町N -> 町N-1 -> 町1 の最短経路の長さ ans_2 = bfs(0, N-1) + bfs(N-1, N-2) + bfs(N-2, 0) ans = min(ans_1, ans_2) if ans < INF: print(ans) else: print(-1)