如何存储Dijkstra算法的相邻节点?

关于Dijkstra算法的大多数文章仅关注应该使用哪种数据结构来执行节点的“放松”.

我打算使用一个在O(m log(n))上运行的min-heap.我相信.

我真正的问题是我应该使用什么数据结构来存储每个节点的相邻节点?
我正在考虑使用邻接列表,因为我可以在O(deg(u))中找到u上的所有相邻节点,这是最快的方法吗?

这将如何改变算法的运行时间?

解决方法

使用Dijkstra的算法,您只需循环一个节点的邻居列表,因此在每个节点(如在邻接列表中)存储相邻节点(或简单地在全局列表中的索引)的简单数组或链表就足够了.

这将如何改变算法的运行时间? – 与什么相比?我很确定算法复杂性假定了邻接列表实现. The running time is O(edges + vertices * log(vertices)).

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...