結果
問題 | No.679 不思議マーケット |
ユーザー |
|
提出日時 | 2019-08-29 18:28:17 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 83 ms / 2,000 ms |
コード長 | 756 bytes |
コンパイル時間 | 183 ms |
コンパイル使用メモリ | 82,228 KB |
実行使用メモリ | 77,312 KB |
最終ジャッジ日時 | 2024-11-17 16:59:41 |
合計ジャッジ時間 | 2,084 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 18 |
ソースコード
from collections import defaultdict, deque def topological_sort(edges): #edges: directed edge ins = defaultdict(int) outs = defaultdict(list) for v1, v2 in edges: ins[v2] += 1 outs[v1].append(v2) q = deque([v for v in range(n) if ins[v] == 0]) res = [] while q: v1 = q.popleft() res.append(v1) for v2 in outs[v1]: ins[v2] -= 1 if ins[v2] == 0: q.append(v2) return res n, m = map(int, input().split()) edges = [] for _ in range(m): gi, ri = map(int, input().split()) h = list(map(int, input().split())) for hi in h: edges.append((hi-1, gi-1)) print(len(topological_sort(edges)))