华南理工大学学报(自然科学版) ›› 2017, Vol. 45 ›› Issue (1): 66-73.doi: 10.3969/j.issn.1000-565X.2017.01.010

• 计算机科学与技术 • 上一篇    下一篇

节点约束型最短路径的分层Dijkstra 算法

康文雄 许耀钊   

  1. 华南理工大学 自动化科学与工程学院,广东 广州 510640
  • 收稿日期:2016-05-20 修回日期:2016-09-03 出版日期:2017-01-25 发布日期:2016-12-01
  • 通信作者: 康文雄( 1976-) ,男,博士,副教授,主要从事计算机视觉及生物特征识别研究. E-mail:auwxkang@scut.edu.cn
  • 作者简介:康文雄( 1976-) ,男,博士,副教授,主要从事计算机视觉及生物特征识别研究.
  • 基金资助:

    国家自然科学基金资助项目( 61573151, 61105019) ; 广东省自然科学基金资助项目( 2016A030313468)

A Hierarchical Dijkstra Algorithm for Solving Shortest Path from Constrained Nodes

KANG Wen-xiong XU Yao-zhao   

  1. School of Automation Science and Engineering,South China University of Technology,Guangzhou 510640,Guangdong,China
  • Received:2016-05-20 Revised:2016-09-03 Online:2017-01-25 Published:2016-12-01
  • Contact: 康文雄( 1976-) ,男,博士,副教授,主要从事计算机视觉及生物特征识别研究. E-mail:auwxkang@scut.edu.cn
  • About author:康文雄( 1976-) ,男,博士,副教授,主要从事计算机视觉及生物特征识别研究.
  • Supported by:

    Supported by the National Natural Science Foundation of China( 61573151, 61105019) and the Natural Science Foundation of Guangdong Province( 2016A030313468)

摘要: 针对节点约束型最短路径问题,提出了基于回溯法的分层Dijkstra 算法,通过分 层结构寻找局部最优解来求得全局最优解或次优解.该算法利用分层结构可保存搜索进 度的优势,使其在寻找过必经点最短路径时可以实现对搜索进度的保存与回溯等操作.实 验结果表明: 分层Dijkstra 算法虽然增加了一定的空间复杂度,但能有效地减少Dijkstra 算法的调用次数; 与深度优先搜索、几何代数算法相比,分层Dijkstra 算法虽然不一定能 找到理论最优解,但出解速度较快,在数据量较大的情况下能快速找到次优解.

关键词: 路由算法, 最短路径, 节点约束型, 回溯法, 贪心算法法

Abstract:

In order to obtain the shortest path from constrained nodes,a hierarchical Dijkstra algorithm is proposed on the basis of backtracking,which is able to find the global shortest path or the second shortest path by searching the local optimal solution within hierarchical structures.Moreover,this algorithm takes full advantage of the hierarchical structures in saving search progress to realize such operations as the saving and backtracking of the search progress during the searching of the shortest path.Experimental results show that the proposed algorithm increases space complexity slightly,but it can reduce the calls of Dijkstra algorithm effectively,and that,as compared with depth-first search algorithm and geometric algebra algorithm,the proposed algorithm may not always find the optimal solution in theory,but it works faster and can still find the sub-optimal solution more quickly even when data volume is large.

Key words: routing algorithms, shortest path, node constraint, backtracking, greedy algorithm

中图分类号: