微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

找到满足给定约束的最小顶点集

如何解决找到满足给定约束的最小顶点集

注意:不需要形式证明或任何东西,只需算法的大致思路,我自己会更深入。

给定一个有向图:G(V,E),我想找到最小的顶点集T,这样对于{{1}中的每个顶点t }} 以下边不存在:T 中的 {(t,v) | for every v outside t}

换句话说,允许 O(V+E)t 之外的顶点获取边,但不能发送。

(你可以用电话来演示,外面可以给我打电话,是免费的,但不能从我这边打电话)


我认为这个问题与在时间复杂度为 T 的有向图中查找所有强连通分量 (scc) 非常接近或相似,我正在考虑构建一个新图并运行此算法但并不完全确定。

解决方法

主要思想是将 G 的每个强连通分量 (SCC) 收缩为单个顶点,同时记录收缩了多少个顶点以创建收缩图中的每个顶点(G 的凝聚)。结果图是有向无环图。答案是出度等于0的顶点中得分较低的顶点。

由于对边的限制,答案结构是强连通分量的并集,您可以证明由于最小限制,答案中只涉及 SCC。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。