結果
問題 | No.2565 はじめてのおつかい |
ユーザー |
|
提出日時 | 2023-12-02 15:26:53 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 186 ms / 2,000 ms |
コード長 | 921 bytes |
コンパイル時間 | 176 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 89,984 KB |
最終ジャッジ日時 | 2024-09-26 18:42:01 |
合計ジャッジ時間 | 9,019 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 50 |
ソースコード
import sysinput = lambda: sys.stdin.readline()[:-1]sys.setrecursionlimit(1000000)import heapqn, m = map(int, input().split())G = [[] for i in range(n)]for i in range(m):u, v = map(int, input().split())G[u-1].append(v-1)def bfs(u, v, v2):q = [u]dists = [-1]*ndists[u] = 0now = 1while q:new_q = []for i in q:for j in G[i]:if dists[j] == -1:new_q.append(j)dists[j] = nownow += 1q = new_qreturn dists[v], dists[v2]p, pp = bfs(0, n-1, n-2)ppp, pppp = bfs(n-1, 0, n-2)ppppp, pppppp = bfs(n-2, 0, n-1)if p == -1 or pppp == -1 or ppppp == -1:if pp == -1 or ppp == -1 or pppppp == -1:print(-1)else:print(pp+ppp+pppppp)elif pp == -1 or ppp == -1 or pppppp == -1:print(p+pppp+ppppp)else:print(min(p+pppp+ppppp, pp+ppp+pppppp))