题目
解法:
这道题目有个关键是,图里面n个节点,有n-1条边,而且题目也提示了可以看作是一棵树。关键在于理解每个节点都指向0代表什么:代表的是每个以0作为根节点,每个叶节点到根节点的路径都是子节点指向父节点的。比如第一个例子,只需要保证2到0和5到0这两条路径都是子节点指向父节点的。而对于connections里面的边,一定是有一个在树里是父节点,另一个是子节点,我们只需要保证这两个节点的相对顺序即可,那么解法就很清晰了:
- 从0节点出发,利用BFS或者DFS遍历一遍树,并且保存每个节点被访问的相对顺序
- 遍历一遍边,根据之前保存的访问的相对顺序是不是符合边的指向关系,如果不符合,表明这条边需要反转
当然也可以通过保存每个结点的父节点来判断相对关系,但是相对来说上面这种方法更加方便
BFS版本
class Solution:
def minReorder(self, n: int, connections: List[List[int]]) -> int:
tree = collections.defaultdict(list)
# create graph to store the adjacent nodes
for edge in connections:
tree[edge[0]].append(edge[1])
tree