結果
問題 | No.1817 Reversed Edges |
ユーザー | H3PO4 |
提出日時 | 2022-01-21 21:36:21 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 678 ms / 2,000 ms |
コード長 | 877 bytes |
コンパイル時間 | 146 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 73,344 KB |
最終ジャッジ日時 | 2024-11-25 23:00:07 |
合計ジャッジ時間 | 11,755 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 23 |
ソースコード
import sys from collections import deque input = sys.stdin.buffer.readline sys.setrecursionlimit(10 ** 9) N = int(input()) T = [[] for _ in range(N)] edges = [tuple(int(x) - 1 for x in input().split()) for _ in range(N - 1)] for i, (a, b) in enumerate(edges): T[a].append((b, i)) T[b].append((a, i)) d = deque([(0, -1)]) rev_edges = [None] * (N - 1) while d: v, p = d.pop() for x, i in T[v]: if x == p: continue rev_edges[i] = (v > x) d.append((x, v)) ans = [0] * N cur = rev_edges.count(True) def rec(v, p): global cur ans[v] = cur for x, i in T[v]: if x == p: continue cur += -1 if rev_edges[i] else 1 rev_edges[i] = not rev_edges[i] rec(x, v) cur += -1 if rev_edges[i] else 1 rev_edges[i] = not rev_edges[i] rec(0, -1) print(*ans, sep='\n')