我需要找到一种算法,用于在 O(n+m) 中找到有向图中的所有根。
我有一个查找单个根的算法:
- 在 V 中的某个 v 上运行 DFS(v)。如果结果是单生成树,则 v 是根。否则,结果就是一片树林。然后:
- 在最后一棵树的根上运行 DFS(u)。如果结果是单生成树,则 u 是根。否则,图中没有根。
现在,如果我想找到所有的根,每次在最后一棵树的不同顶点上运行上述算法 O(n) 次的最佳方法是什么?假设我找到了一个根,如果另一个根存在,那么它必须在最后一棵树上,那么如果我继续运行上述算法直到收到“不存在根”或直到遍历所有顶点,它是 O(n+m) 吗?
提前致谢 !