結果
問題 |
No.92 逃走経路
|
ユーザー |
|
提出日時 | 2018-06-22 23:46:08 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 139 ms / 5,000 ms |
コード長 | 710 bytes |
コンパイル時間 | 479 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 11,392 KB |
最終ジャッジ日時 | 2024-06-30 18:09:25 |
合計ジャッジ時間 | 2,085 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 18 |
ソースコード
from collections import defaultdict def solve(): n, m, k = map(int, input().split()) mip = defaultdict(list) mpi = defaultdict(list) for i in range(m): a, b, c = map(int, input().split()) mpi[c, a].append(b) mpi[c, b].append(a) mip[c].append((a, b)) d = tuple(map(int, input().split())) v = (set(), set()) for a in mip[d[0]]: v[0].add(a[0]) v[0].add(a[1]) if k == 1: return v[0] a1 = 0 a2 = 1 for i in range(1, k): for x in v[a1]: for b in mpi[d[i], x]: v[a2].add(b) v[a1].clear() a1, a2 = a2, a1 return v[a1] v = sorted(solve()) print(len(v)) print(*v)