首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Dijkstra结束条件

Dijkstra结束条件
EN

Stack Overflow用户
提问于 2014-05-28 08:33:38
回答 1查看 5.4K关注 0票数 5

对于Dijkstra,您使用结束条件。

代码语言:javascript
复制
   while(!q.isEmpty()){
       //Some code
   }

但是,如果您知道结束节点,是否不可能将结束条件更改为

代码语言:javascript
复制
   while(!q.peek().equals(endNode){
       //Some code
   }

我见过的Dijkstra的每个实现都使用更早的实现,但当您知道结束节点时,后者使用的更快。还是这不是Dijkstra了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-28 08:39:46

取决于你想要算法做什么。最初的Dijkstra算法计算从源到彼此顶点的最短路径的长度。如果您有一个目标顶点,则可以在将目标从队列中弹出后缩短该算法。

快捷方式的正确性可以很容易地被证明:Dijkstra从不改变它已经从队列中弹出的节点的最短路径长度,所以您知道如果您继续运行算法直到队列为空,您将看到它返回的长度。

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

https://stackoverflow.com/questions/23906530

复制
相关文章

相似问题

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