码迷,mamicode.com
首页 > 其他好文 > 详细

BFS 两个重要性质

时间:2018-04-15 19:45:27      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:快捷   col   应该   程序   一个   而且   优化   i+1   方便   

对于进行广度优先搜索的队列中,应该始终满足两个性质:

 

性质1:若队首为第i层拓展到的节点,则队列中最多只能存在第i层和第i+1层的节点,不可能出现3层节点。

 

性质2:队列中的元素会严格按照层数单调递增,而且会按照入队的先后来判别拓展的优先程度,即先入队的一定是更优先的,而越往后越次之。

 

通过这两个性质,其实我们就可以更严格更方便更快捷更明确地设计有关BFS的程序,当已经找到一个目标节点,即可以终止程序(or过程)。

而对于单调性的优化,则可以使用单调队列、双端队列、优先队列代替普通队列,进而达到性质2的设计,不过要就具体情况分析。

BFS 两个重要性质

标签:快捷   col   应该   程序   一个   而且   优化   i+1   方便   

原文地址:https://www.cnblogs.com/Ronald-MOK1426/p/8848716.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!