繁体   English   中英

在邻接列表中返回空边缘描述符 [C++ BGL]

[英]Returning a Null Edge Descriptor in an adjacency list [C++ BGL]

在征求有关如何在无向图中找到边的建议后,我希望调整他的函数以在找不到边时返回空边。 我知道 boost 有一个空顶点( graph_traits<G>::null_vertex() ),但我没有在任何文档中找到一个边。 有没有人有解决上述问题的方法?

没有零边。 根据您的图形模型,您可以设想一个,但这意味着您必须

  • 使用实现细节(具体来说, nullptr可能很适合,但与任何 BGL 函数一起使用永远不会安全)
  • 制作您自己的图形概念模型,以便您控制实现细节

在实践中,我会使用表达意图的词汇类型。 例如,如果您有一个搜索函数返回一个边缘,除非找不到,我会返回:

std::optional<edge_descriptor> my_search();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM