对图表进行排序,使尽可能多的箭头指向前方

发布于 2024-07-17 16:20:15 字数 146 浏览 12 评论 0原文

我需要对有向图的节点进行排序,以使向后流动(与排序顺序相反)的箭头数量最少。

我可以想到算法(例如,继续交换节点,直到没有交换会改善情况),但我不确定它们运行的​​速度有多快,或者它们是否达到最佳解决方案。

这个问题的名称和复杂性是什么?

I need to sort the nodes of a directed graph such that the number of arrows that flow backwards (against the sorting order) is minimal.

I can think of algorithms (e.g. keep swapping nodes until no swap will improve things) but I'm not sure how fast they run or whether they arrive at the best solution.

What is the name and complexity of this problem?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

尘世孤行 2024-07-24 16:20:15

按深度顺序对节点进行排序可以使用拓扑排序来完成。但是,这只有效与不包含循环的图。 你的问题听起来像是图中有循环。 一种选择是找到周期(请参阅龟兔赛跑算法,了解一种方法这个)并打破循环,记录你打破它的地方。 然后对节点进行排序并重新链接。

如果您这样做是出于可视化目的,则有一个名为 GraphViz 的图形渲染库,它的功能与您正在描述然后布置节点。 它易于集成和使用,并将渲染到屏幕或各种不同的输出格式。

Sorting nodes in order of depth can be done with a topological sort. However, this will only work with graphs that contain no cycles. Your problem sounds like there are cycles in the graph. One option would be to find the cycles (see the Tortoise and Hare algorithm for a method of doing this) and break the cycle, recording where you broke it. Then sort the nodes and re-link.

If you are doing this for visualisation purposes there is a graph rendering library called GraphViz that does something very similar to what you are describing and then lays out the nodes. It is easy to integrate and use and will render to the screen or a variety of different output formats.

ぃ双果 2024-07-24 16:20:15

经过一番思考后,我意识到问题可以分为两部分:

  1. 确定图的最大非循环子图(其中 是 NP 难题
  2. 对其进行拓扑排序(要容易得多)

After some thought I realized that the problem can be split in two:

  1. determine a largest acyclic subgraph of a graph (which is NP-hard)
  2. topologically sort it (which is a lot easier)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文