首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用OGDF库在无圈有向图中找到最长路径?

如何使用OGDF库在无圈有向图中找到最长路径?
EN

Stack Overflow用户
提问于 2012-08-03 06:17:14
回答 1查看 586关注 0票数 1

我是OGDF库的新手,需要在非循环有向图中找到最长路径(我想使用OGDF内置函数)。我知道,使用具有负权重的最短路径算法可以找到最长路径,但也找不到合适的函数。OGDF有没有特定的功能来做到这一点?如果是,我如何使用它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-12 04:44:24

在OGDF中,您可以使用ShortestPathWithBFM找到节点s和其他节点之间的最短路径。应使用EdgeArray<int>将边的长度(权重)传递给函数。下面是来自源代码的类定义:

代码语言:javascript
复制
namespace ogdf {

class OGDF_EXPORT ShortestPathWithBFM : public ShortestPathModule
{
public:
 ShortestPathWithBFM() { }

 // computes shortest paths
 // Precond.:
 //
 // returns false iff the graph contains a negative cycle
 bool call(
 const Graph          &G,      // directed graph
 const node           s,       // source node
 const EdgeArray<int> &length, // length of an edge
 NodeArray<int>       &d,      // contains shortest path distances after call
 NodeArray<edge>      &pi
 );


};


} // end namespace ogdf

如果您传递的长度为负数,该算法将计算最长路径。如需更多信息,请访问:http://www.ogdf.net/doc-ogdf/classogdf_1_1_shortest_path_with_b_f_m.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11786627

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档