c++ - 图中边的顶点之间的最短路径不应是边本身

标签 c++ c algorithm graph

我需要找到加权无向图中每条边的最短替代路径,即,假设我在图中有一个 egde (a,b),然后我想计算顶点 a 和 b 之间的最短路径跳过直接路径,即 edge(a,b) 。如果没有替代路径,那么距离应该是无限的。我会为图形的每条边执行此操作。我尝试使用 dijkstras 算法(遇到目标顶点时会中断)但是为每条边单独计算路径需要太多时间,特别是在没有其他选择的情况下路径是可能的(在这种情况下,必须遍历整个图)。您能否对此提出任何其他替代解决方案。

最佳答案

我想我要做的是调整 Dijkstra 的算法,以便我最初使用所有不使用该边的长度为 2 的路径填充堆/优先级队列(感谢 titus 发现了我之前的错误)。这样,您得到的结果将排除只包含一条边的路径。然后,结果会为您提供一个特定来源的所有内容,您可以对所有可能的来源重复此操作。

关于c++ - 图中边的顶点之间的最短路径不应是边本身,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11888452/

相关文章:

c++ - 使用 boost spirit 语法构建错误(boost 1.43 和 g++ 4.4.1)

c - 在 C 中使用系统调用读取和搜索文件

c - 如何在一个 do while 循环中同时运行三个 do while 循环?

c++ - 如何从Qt5中的QVariant获取QString形式的数据?

c++ - 使用 typedef 摆脱 GCC 中的 `deprecated conversion from string constant to ‘char*’ ` 警告?

c++ - C/C++ 语言的新手。出了什么问题?

c - 如何在 C 中将字符串转换为数值?

java - 难以理解神经网络中的反向传播算法

c# - 找到完全覆盖矩形集所需的最少固定大小矩形的算法

c++ - 标准 :out_of_range in mergesort