DFS之前在回溯法中已经介绍过了
BFS主要是用队列实现,具体模版是入队第一个元素,当队列不为空时进行循环,如果需要记录每层的数据(层数),就保存队列的长度,在队列不为空的循环里进行for长度的循环,先出队第一个元素,进行条件判断,满足条件的节点入队。
BFS主要应用于二叉树层次遍历相关、二叉树的右视图、求二叉树/简单图的最短/最小路径,拓扑排序,单词接龙等,图的遍历、克隆图、由图判树、连通快问题、岛屿数量等等,红色表示还未攻克
能用BFS解决的千万用BFS解决不要用DFS解决!!
DFS之前在回溯法中已经介绍过了
BFS主要是用队列实现,具体模版是入队第一个元素,当队列不为空时进行循环,如果需要记录每层的数据(层数),就保存队列的长度,在队列不为空的循环里进行for长度的循环,先出队第一个元素,进行条件判断,满足条件的节点入队。
BFS主要应用于二叉树层次遍历相关、二叉树的右视图、求二叉树/简单图的最短/最小路径,拓扑排序,单词接龙等,图的遍历、克隆图、由图判树、连通快问题、岛屿数量等等,红色表示还未攻克
能用BFS解决的千万用BFS解决不要用DFS解决!!