分享 BFS 模板:
BFS使用队列,把每个还没有搜索到的点依次放入队列,然后再弹出队列的头部元素当做当前遍历点。
BFS总共有两个模板:
模板一:
如果不需要确定当前遍历到了哪一层,只需要访问完所有节点就可以时。
BFS 模板如下:
while queue 不空: cur = queue.pop() if cur 有效且未被访问过: 进行处理 for 节点 in cur 的所有相邻节点: if 该节点有效: queue.push(该节点)
模板二:
如果要确定当前遍历到了哪一层,需要知道最少移动步数时,BFS 模板如下。
这里增加了 level 表示当前遍历到二叉树中的哪一层了,也可以理解为在一个图中,现在已经走了多少步了。size 表示在当前遍历层有多少个元素,也就是队列中的元素数,我们把这些元素一次性遍历完,即把当前层的所有元素都向外走了一步。
1 level = 0 2 while queue 不空: 3 size = queue.size() 4 while (size --) { 5 cur = queue.pop() 6 if cur 有效且未被访问过: 7 进行处理 8 for 节点 in cur的所有相邻节点: 9 if 该节点有效: 10 queue.push(该节点) 11 } 12 level ++;
上面两个是通用模板,在任何题目中都可以用,是要理解并且记住的!
标签:queue,遍历,cur,bfs,BFS,节点,模板 来源: https://www.cnblogs.com/r1-12king/p/16300406.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。